الأسس العلمية لقواعد البيانات - منتديات الفريق العربي للبرمجة 
InternetMaster‏ 


مشاركات في عام(2003) ليس لها مثيل بواسطة خبير قواعد البيانات : 


InternetMaster 
. تم تجميعها من قبلي لتعم الفائدة للجميع‎ 
وقد بين في احدى المشاركات عدم ممانعته تجميع المشاركات و نشرها‎ 


عماد حمدي يوسف 
العراق بغداد 
2010/03/04 


مرحباء»» 


يبدو أنني ممن إنضم لهذا الموقع متأخراً بعض الشيء حيث لم أسمع به من 
قبل» ويظهر من قراءتي لبعض المشاركات أنئي قد فقدت فترة إزدهار هذا 
الموقع!! 


بعد إنضمامي ببضعة أيام ومحاولاتي للإجابة على بعض أسئلة زوار الموقع 
إتض لاص أن هاف خاد في افاج اة قر اع انياتات 


وعليه فقد طلب مني بعض الأخوة في هذا الموقع شرح الأسس العلمية لقواعد 
البيانات وحيث أن لدي وقتا لعمل هذا حتى 15 رمضان فسأحاول جهدي أن 
أضع بين أيدي زوار الموقع ومنسوبيه خبرة أكثر من 20 عاما في البرمجة. 
و سنركز على جزئية قواعد البيانات بالدرجة الاولى. 

في هذه الدروس السريعة حتى يصل معنا بمشيئة الله إلى المفاهيم الصحيحة 
لقواعد البيانات. 


كل ما أطلبه ممن يستفيدوا من هذه الشروحات المتواضعة هو دعوات صادقة 
لي في هذه الأيام المباركةء أم من لم يستفد فآمل منه أن يتقبل إعتذاري على 
إضاعة وقته. 


فبإسم الله نبدا وعليه نتوكل. 


تحیاتی›»› 


مرحباء»» 


في البداية آمل ممن يقرا هذه الوريقات أن يتنبه إلى أنني وضعت هذه الدروس 
في قسم 55 ع٥٥۸‏ لكثرة عدد الزوار في هذا القسم» وعليه فالشرح هنا يتحدث 
عن قواعد البيانات بالدرجة الأولى وليس عن نوع واحد فقط عند تعلماک 
للأسس الصحيحة لقواعد البيانات تصبح البرامج التالية في منتهى السهولة 
والبساطة. 


Access 
FoxPro 
Clipper 
DBase 


Microsoft SQL 
Oracle 
Sybase 


كل ما سبق عبارة عن برامج لشركات مختلفة تستخدم أدوات قواعد البيانات» 
للتوضيح يوجد مصطلح" سيارة "فعند التحدث عن السيارة يكون عن كيفية 
عا ونا ا وض اها رر کون الخدت ع مت من هن ارات 


مرة أخرى كل ما سيتم وضعه هنا هو عن قواعد البيانات التي تساعد الجميع 
على الفهم وليس التطبيق والتقليد والمحاولة والخطأ. 


وعليه فبإمكان من يقرأ هذه الدروس أن يدل عليها الأخوة في الأقسام الأخرى 


مثل أوراكل وساي بيز وميكروسوفت أس كيو إل. 


تحیاتی›»› 


مرحباء»» 


من خبرة سابقة في تقديم المحاضرات في بعض المؤتمرات والمحافل الرسمية 
والدورات التدريبية... قد تفاجأً عزيزي القارىء من طلباتي التالية: 


إذا أردت إحتراف قواعد البيانات فعليك إتباع التالي: 


وآله حاسبة!! 
إقرأً الفاتحة وإبدأ بإسم الله الرحمن الرحيم. 


إذا راودتك نفسك أن تفتح الأكسس وتقوم بالتطبيق فلن تفهم شيئًا!! 
إذا راودتك نفسك أن تسأل أي سؤال يبدأ بكيف؟ فلن تفهم شيئًا!! 


في نظرية التعلم هناك سؤالين الأول كيف والآخر لماذا؟ 


كيف؟ سهلة جدا إعمل كذا وكذا ثم كذا وكذا !إهذا لا يصنع منك إلا مقلدا!! 
لماذا؟ تتطلب فكرا وعمقا وهدوءاء وهذا ما سنفعله في هذه السلسة من 
الشر وكات هر مخارلة ايبصال مهرد ادا 


لماذا ننشاً هذا الجدول؟ لماذا بهذه الطريقة؟ لماذا الإستعلام وما هي أهميته؟ 
وهکذا 
ینن كيف نشا جدول بل لماذا نضع هذا الجدول عوضا عن ذأف!!! 


مرة أخرى» لا حاسب» لا آکسس لا اس کيو إل» لا شيء» في هذه الدروس 
ستكون أنت الأكسس» أي انت من سيقوم بعمل الأكسس او 6۵41 او أوراكل. 


إذا نجحت بتوفيق الله ان أجعل من تفكيرك وعقلك أن يقوم بعمل أي برنامج 
لقواعد البيانات بعدها سيكون كل ما هو مطلوب منك الإجابة على كيف أعمل 


هذا في الأكسس أو كيف أعمله في أوراكل وتصبح العملية في منتهى البساطة 
والسهولة والسلاسةء لماذا؟ 


لأنه عندها سيكون لديك كافة الأسس العلمية لقواعد البيانات. 


تحیاتی›»› 


مرحباء»» 


قواعد البيانات !!! لاحظ كلمة البيانات» والبيانات هي مجموعة لا معنى لها 
من الأرقام والكلمات... البيانات أي شىء مثل كلمة" ربح "كلمة" خسارة "رقم 
"2000 "و هكذا... 


البيانات لا تعني شيئا هذه أول خاصية من كلمة بيانات أنها لا تعني أي شىء» 
والبيانات لا يستفاد منها إطلاقا!! 


الخاصية الثانية لكلمة بيانات هي الحجم» حيث أن البيانات دائما تعني الكثرة 
و الضخامة من خت العدداا 


وهذا يضع كلمة بيانات في موقع سىء حيث أنها ضخمة وكثيرة ومتشعبة وفي 
نفس الوقت لا معنى لها. 


كلمة قاعدة تعني تنظيم الشىء على أسس» وهذا ما يتم في قواعد البيانات» هو 
تنظب اومن ثم ت ابا 1 أماذ۱؟ 


لماذا نقوم بتحليل وتنظيم البيانات؟ الإجابة هي... لتحويل البيانات إلى 
معلومات!!! 


SS 


من خلال معالجة البيانات تتحول إلى معلومات --- قاعدة أساسية في غاية 
الأهميةء الهدف إذا هو تحويل البيانات إلى معلومات. السؤال البديهي لماذا 
نقوم بهذه العملية؟ 


لسببين أساسيين: 


الأول: هو إتخاذ القرارات. 
الثاني: التخطيط 


اغ اتات تمل ك اكان اة العر الج م كات ۷ فة ني 
ولكن عند معالجة البيانات وتحويلها إلى معلومات يصبح لدينا التالي مثلا: 


عدد الأطفال في تحت العشرة سنين %30 هي معلومة تتطلب التخطيط لبناء 
مدا 
رس 


مثال آخر أرباح السنة المالية الحالية %35 هنا لدينا معلومة نستطيع أن نتخذ 
عليها قرارا" إتخاذ القرارات "مثل توزيع راتب إضافي لمنسوبي الشركة. 


وک کات کڪ تحرنل ااات لے ا من امسات 
المتدفة لسا عة على اتخا الق ر ارات و اطاط 


سيكون مشروعنا هو بناء قاعدة بيانات لإدارة مستوصف -- مرة أخرى لا 
تندرې عزيزي القارىء --- لن نستخدم أي برنامج ولن نستخدم أي حاسب آلي 
بن ر بای على الحا اال ن ر فا ب مقي 

الآن أطلب منك عزيزي القارىء مزيدا من التركيز... 


الطبقات الثلاث. 


حتى وإن كان ما سبق خطأ وهو تصميم قديم» لكني أطلب منك عزيزي 
القارىء أن تحفظها حتى لو كانت خطا" الطبقات الثلاثة" 


الطبقة الأولى۲ ٣|٥‏ ك۴ 
وهي ما يسمى بالمقدمة أو واجهة ازunتخدnterfacep| User‏ 


الطبقة الثانية ۲6 S60٩٩‏ 
وهي ما يسمى بطبقة المنطق والقو انين |١6٥‏ اوها 


الطبقة الثالثة !۲ ۲|۲۹۵ 
وهي ما يسمی بالخلفية ٤٩۵‏ )٥ج8‏ وهي طبقة ؟؟؟ قواعد البيانات!! 


لماذا از عجتك عزیزي القار ىء بهذه المصطلحات؟ 
لأسباب بسيطة وصغيرة جدا: 


قم بنسيان النماذج في الأكسس 
قم بنسيان التقارير في الاکریس 


النماذج والتقارير الموجودة في الأكسس ليست للإحتراف وليست للبرامج 
اة أ عة الات اة 


لماذا هذه الزحمة؟؟؟ 

لأنه لا يوجد شيء في قواعد البيانات أسمه نماذج أو تقارير» النماذج 
والتقارير تصنع في الطبقة الأولى وليس الثالثة. الطبقة الثالثة لقواعد البيانات 
بينما الطبقة الأولى هي للنماذج والتقارير. 

للمعلومية وقد يسعفنا الوقت لشرح المزيد لاحقا: 

Visual Basic .NE 1 مدخت~i‎ --- الطبقة الأولى‎ 

Visual C++ .Neanدختسن‎ --- الطبقة الثانية‎ 

Sybaseg Oracle si Microsoft SQL pدختi‎ --- الطبقة الثالثة‎ 


لماذ| ا5س و MySQL sڪ Clipper s Dbase s FoxPro‏ 
يستخدمون الطبقات الثلاثة مع بعضها البعض في محتوى واحد؟ 


الإجابة هي لأن هذه التطبيقات للإستخدام الشخصي فقط !!! وليس لصناعة 
قواعد بيانات للسوق. إلا في حالات شاذة جدا مثل أن يكون عدد المستخدمين 
صغير أقل من 10 أشخاص فقط. 


لهاد ردت ار تطح اكرات 

آخر هده المشاركة: 

هناك كلمتان في غاية الأهمية وقطعا تعرln Servers Client‏ 
قواعد البيانات دائما وأبداً على -- 56۲۷6۲ الطبقة الثالثة 


الواجهات والنماذج والتقارير دائما وأبدا على -- ها٥‏ الطبقة الأولى" يشذ 
عن هذا تطبيقات الإنترنت "وهذا موضوع آخر فيما بعد بمشيئة الله. 


المسافة بين أ٣‏ ما٥‏ وال 56۲۷6۲ دائما غير معروفة»ء قد تكون 5 سم او 10 
آلاف كيلو متر› إنتبه هذه النقطة جيدا --- أعيد مرة أخرى المسافة بينهما غير 


تحیاتی›»› 


عند بداية تصميم أي قاعدة بيانات نبدأ بمعرفة أين يقع "ا٥‏ وأين 
يقع 56۲۷6۲ 


نجيب على الأسئلة التالية. 


ما أهمية التواجد المستمر ai۷‏ اأج۸۷ !! إحفظ هذا المصطلح 
جيدا ويعني أن الطبقة الثالثة وهي طبقة قواعد البيانات -- كم يسمح 


لها أن Server ٠‏ و 2 غر ا E‏ 
Ee‏ 

مستخدم البرنامج يجب أن يجيب على هذا السؤال؟ لأنه لو قال لك 
أريد الطبقة الثالثة أن تعمل على مدار السنة دون خروجها من الخدمة 
فهذا يتطلب أن يكون هناك مpں 8٥)‏ خادم آخر یعمل عند سقوط 
الخادم الأساسي» وهذا يؤثر على كيفية بناء قاعدة البيانات. 


السؤال الثاني هو القياس لاأاأاهاهءŠ‏ !! إحفظ هذا المصطلح جيداً 
ويعني کم شخصا سیستخدم قاعدة البیانات؟ کم شخصا سيستخدم 
قاعدة البيانات في نفس الوقت؟ كم عدد السجلات في قاعدة البيانات 
على مدى العشر سنوات قادمة؟ ما هو المطلوب عمله في البيانات 
القديمة هل تحذف آم تخزن؟ هل تخزن على نفس الخادم أم على خادم 
0۳ آخر؟ كيف يتبادل الخادمين المعلومات؟ وهكذا؟ هذا 
القنضر" الفياين "هى الهم غلى الإطلاق. 


عزيزي القارئ... 
عند تصميمك لأية قاعدة بيانات تخيل ما يلى: 


أن قاعدة البيانات فيها 5000 جدول 

أن كل جدول في قاعدة البيانات تحتوي على 10 ملايين سجل 
أنه يوجد 30 آلف مستخدم يتعاملون مع قاعدة البيانات في نفس 
الوقت 

أن المسافة بین 5٥۲۷6۲‏ و ٣٥ا٥‏ آلف كيلو متر 

لماذا هذا التخيل؟ 


لأنه هذا هو الطريق الصحيح لصناعة قاعدة بيانات قوية الأساسات 
وخالية من الأخطاء وستعلم لاحقا لماذا. 


من قرأ معنا حتى الآن ويرى أن قواعد البيانات شوية حقول على 
توليفة أستعلامات على نموذجين وكم تقرير أقترح عليه التوقف عن 
القراءة حيث لن يستفيد شيئا. 


لإنهاء قاعدة بيانات يحصل بها على ترقية أو يتفاخر بها مع اخوته 
وأصدقائه» وعليه تنتقل المفاهيم الخاطئة من شخص لآخر ببساطة 
ويصبح الاأكسس" عفوا البرنامج التافه "هو قمة الإبداع والبرمجة. 


عفوا وعذرا لمحبي الآكسس -- كل ما أحاول عمله في البداية هو 
توضيح للمفاهيم ثم المصطلحات قبل أن نبدأً السباحة. 


أين الطبقة الثانية --- ۲16۲ ءاوه[ دعك منها الآن 


كل تركيزنا حتى هذه اللحظة منصباً على الطبقة الثالثة وهي قواعد 
البيانات. 


آمل عزيزي القارئ أن تكون في هذه اللحظة قد جهزت براية ومحاية 
ودفتر ومسطرة وآلة حاسبة ومجموعة أقلام رصاص. 


ن لم تكن قد فعلت وتريد أن تكمل معا من متطاق" الهاو "و" الراك 
الجدع "على رأي الأخوة في مصر؛ أو منطلق سأفهم فيما بعد أو 
منطلق حلولي المشكلة التي بين يدي» أو منطلق سأجمع المشاركات 
ثم أقوم بدراستها وقراءتها فيما بعد --- صدقني لن تصل بقواعد 
البيانات إلا إلى طرق مسدودة وبعد عدة أشهر ستلغي الموضوع 
برمته. أو على أضعف الإحتمالات لن تبيع قاعدة بيانات واحدة على 
الإطلاق. 


الحاسب ال إطلاقا وهيا بنا نصمم قاعدة بيانات لإدارة مستو صف 


بالطرق العلمية الصحيحة. 


مرة أخرة يا أخوتي وأخواتي -- سنصمم يدوياً ولیس بإستخدام 
الحاسب الائ او الاکىس او غیره. 


تخباتے): 


مرحباء»» 
مسطرة 


خا 
براية 

الة حاسبة صغيرة 
دفتر کبیر 

أقلام رصاص 


RE N 
وسيبقى يلف ويدور ويسأل ويحاول ويخطىء وهكذا دواليك.‎ 


أمل ممن يستخدمون الآكسس الآن أن يوقفوه فوراً --- من سيطبق 
على الاكسس او آي برنامج غیره --- والله لن يستفید شیئا. 


الأسلوب العلمي لتصميم قواعد البيانات يبدا بتحديد شكل المخرجات 
او ما يعرف بإسم التقارير وعليه تكون التقارير هي أول خطوة 
يجتمع عليها فريق العمل مع صاحب المشروع للإتفاق على شكلها 


لاحظ عزيزي القارئ --- لا تصمم أبدا أبدا أبدا أبدا أي قاعدة بيانات 
قبل أن يكون لديك على أوراق عادية كل التقارير المطلوبة من 
المشروع. وحيث أن هذه الدروس لتعميق مفاهيم قواعد البيانات 
بشكلها آلعلمي الصحيح فسأضطر إلى مخالفة هذه القاعدةء ولكن 
سنعود آليها قريبا جدا عندما نطبق مشروعنا الثاني والذي ستقومون 
أنتم بعمله تحت إشرافي بمشيئة الله عز وجل. 


في الأسلوب العلمي الصحيح عند بناء قاعدة بيانات نبدأ بالتقارير تم 
نصمم الجداول ثم الإستعلامات ثم .... لن أقول لكم الآن حتى لا 
ا 


لغرض هذا الدرس الأول ولخبرتي في أفضل طرق إيصال المعلومة 
سأقوم بتوجيهكم خطوة خطوة بدأ بالجداول ثم الإستعلامات ثم 
التقارير --- أعلم أنه خطأ ولكن لأنه المثال الأول وأعلم أنه سيكون 
مفيدا بإذن الحق تبارك وتعالى. 


برنامج قاعدهة بیانات لإدارة مستو صف 


لبناء الجداول نبداً بتحديد أقصى بعد لمكونات المشروع" في حالتنا 
يتکون من: 

أطباء 

عیادات 

مرصضصی 

في قواعد البيانات هناك الوظيفة الأساسية والوظائف الفرعية -- ما 


هي الوظيفة الأساسية للمستوصف -- علاج المرضى" بإذن الله " 
وكذلك تحقيق أرباح 


إذا تم تعريف الوظيفة الأساسية للمشروع --- علاج المرضى -- 
بدون مرضى المشروع فاشل ولا معنى له --- إذا الجدول الأساسي 
هو جدول المرضى. 


ف د کک م کن 
ماهي الوظائف الفرعية للمستوصف؟ 


هل يوجد مستوصف بدون صيانة؟ 

هل يوجد مستوصف بدون مقاول للنظافة؟ 

هل يوجد مستوصف بدون إدارة شؤون موظفين؟ 
هل یوجد مستوصف بدون صيدلية؟ 

هل یوجد مستوصف بدون جداول للنوبات؟ 

هل یوجد مستوصف بدون نظام حجز مواعید؟ 


واااو --- العملية بدأت" في الليمونة "على رأي أحبائنا في 


مصر 
العملية بدات تند 


لحظة -- توقف -- إتصل بصاحب المشروع -- صاحب المستوصف 
-- حدد اجتماع 


المشهد: فريق العمل معك أنت بصفتك قائد الفريق مع صاحب 
المستوصف مع مدرائه في غرفة الاجتماعات اأساعة العاشرة صباحا 
-- أمامك قنجان من القهوة" مو في رمضان طبعا" 

ما هو المطلوب من هذا الاجتماع؟؟؟ 


هل قاعدة البيانات المطلوبة هي للوظيفة الأساسية؟ آم للأساسية 


والفرعية أيضا؟ إذا تم دمج الفرعية؟ أي منها؟ 


لهذا السبب قواعد بيانات شوون الموظفين ذائعة الصيت لماذا؟ لأنها 
تصلح لكل منشأة وشركة بغض النظر عن نشاطها. وهكذا للمحاسبة 
والصادر والوارد وغيرها. 


ملاحظة: قد يسعفنا الوقت لاحقا وبتوفيق الله أن نشرح كيف نجعل 
مجمو عة من قواعد البيانات المختلفة أن تتحادث وتتخاطب بين 
بعضها البعض للحصول على تقارير موحدة منها جميعا وهو ما 


Distributed Database Application s٣١ 


توقف --- استمر --- لا بد من تحديد نطاق عمل قاعدة البيانات منذ 


اليوم الأولء يجب أن ينص العقد مع صاحب المشروع على نطاق 
قاعدة البيانات --- لماذا؟؟ 


هيا عاد لا بد أن تيجيب على السؤال !إفكر قبل أن تقرأ الإجابة 


السبب بسيط لأنه عند إكتمال قاعدة البيانات ومن ثم يتغير نطاق 
العمل تتغير الجداول تتغير العلاقات تتغير الإستعلامات تتغير 
التقارير --- مصيبة كبيرة وخسائر في الوقت والجهد.... إلا إذا كنت 
وحشا من وحوش قواعد البيانات لأنك يمكنك تصميم قاعدة البيانات 
بدون حقول .... واووووو ويقوم مستخدم القاعدة بعمل أية حقول 
كيف يشاء متى يشاء --- واااااووو --- ويستطيع أن يغير النماذج 
ولاو ا عمل ل الل و ویرک کا 
هذا --- أسألوني فيما بعد عن هذا --- موضوع متقدم جدا جدا جدا ٠‏ 
لیس مکانه هنا. 


إنتھی الإجتماع وتم الاتفاق على أن تخدم قاعدة البيانات الوظيفة 
الأطباءء العيادات»› المرضى. 


فارغة في 1 اكتب"الجدول الرئيسي اللمستوضفت 
الحقول التالية. 


أريدك ا تنسى العبارات التالية: نص»› رقم» عملة» كائن»› الخ 


أبدا معي بالكتابة في الصفحة التي ستحمل كافة حقول المشروع ولأن 
التطبيق يدوي فلن أكثر عليكم بالحقول سنزيدها عند التطبيق الفعلي 
على الأكسس لاحقا بمشيئة الله 


الحقول: 

رقم المريض -- 10 خانات 

إسم المريض -- 50 خانة 

جنسية المريض -- 25 خانة 

عمر المريض -- 2 خانة 

جنس المريض -- 1 خانة 

تشخيص المرض -- 350 خانة 
العلاج -- 350 خانة 

الك الف عة من ال وخ2 
تاريخ دخول المريض -- 10 خانات 
وقت دخول المريض --- 5 خانات 
تاريخ خروج المريض --- 10 خانات 
وقت خروج المريض -- 5 خانات 


رقم الطبيب المعالج -- 10 خانات 
أسم الطبيب -- 50 خانة 
جنسية الطبيب -- 25 خانة 


راتب الطبيب الشهري -- 5 خانات 
بدل السكن للطبيب السنوي -- 5 خانات 
بدل النقل للطبيب الشهري -- 5 خانات 
جنس الطبيب -- 2 خانة 


رقم العيادة -- 10 خانات 

أسم العيادة -- 50- خانة 

رقم الجناح الذي تقع فيه العيادة -- 2 خانة 
قالطاو ب 2 خا 


ملاحظات -- 500 خانة 


EEE RE 
e!!! 

من نفذ ما سبق على ورقة بيضاء بخط واضح أن يفتح صفحة جديدة 
في الدفتر ويتقمص شخصية مدخل البيانات وبإستخدام المسطرة 
والقلم أن يرسم جدولاً فيه كافة الحقول السابقة كعناوين للأعمدة وأن 
يسجل 45 سجلاً لزيارات مرضى مع مراعاة ما يلي: 


أن يسجل على الأقل 3 إلى 5 زيارات لكل مريض 
أن يسجل على الأقل 3 إلى 5 علاجات لكل طبيب 
أن يسجل على الأقل 3 إلى 5 استخدامات لكل عيادة 


أن ينوع في أنواع الأمراض' ' كفانا الله وإياكم شرها" 
أن ينوع في جنس المرضى والأطباء 
ن ينوع في الجنسيات 


وهکذا... 


بعد أن تقوم بكتابة 45 سجلاً على الأقل نكون بحمد الله وفضله قد 
إنهينا تصميم قاعدة البيانات !!!!!!!!!!!!! طبعا لأإ!! 


سنقول لماذا في الدرس القادم بمشيئة اله. 


:٤ےتایکت‎ 


مرحباء»» 


لن نكمل مشروع قاعدة البيانات في هذا الدرس لإعطاء من يتابعوننا 
سنحتاجه فيما بعد بشكل كبير جدا والموضوع هو" مدخل البيانات." 


مدخل البيانات هو شخصية تتطلب من مصمم قاعدة البيانات أن 
يفهمها بشكل واضح» ولزيادة عنصر الشوق أقول لكم أنه يوجد 
obsل ori‏ yBوطبعا‏ هذه الدورات للأسف" كالعادة "لا تقدم في 
عالمنا العربي. 

الوظائف المملة امل 9و٣أاه8‏ هي وظائف" لا تستغرب عزيزي 
القارئ "ذات رواتب مرتفعة جدا جدا مع قلة الخبرة والتعليم المطلوب 
فيها !!! لماذا ؟ 


هذه الوظائف يترتب على الخطأ فيها خسائر جمة لصاحب العمل !!! 
بهذه البساطة. 


من أمثلة الوظائف المملة: 


دة الحافلات و النافلات على الخطرط النرية الطريلة نين الذول 
وطبعا صديفنا --- مدخل البيانات 


اذا تعمقت في هذه الوظائف تجد أنه يترتب على الخلل فيها خسائر 
خسارة كبيرة. 


أو سائق شاحنة ينطلق من الرياض متوجها إلى الإمارات مثلا ومعه 
0 سیارات فارهة»ء یترتب على نومه حادث لا قدر الله ينتج عنه 
الكثير من الخسائر. 


وصديقنا مدخل البيانات -- تخيل أن يقوم بإدخال أرقام خاطئة عن 
المبيعات -- يترتب عليها تقارير توضح خسائر بينما الشركة تربح 
و E‏ د 
جداول بيانات خاطئة تعطى نتائج لا معنى لها. ليست مشكلة الحاسب 
الالي انه يعطيك نتيجة جمع 5 و 3 على أنها 8 وأنت تقصد جمع 4 
و 3!!! 


من رأى منكم مدخل بيانات فعليا سيضحك لما أقول» لأن مدخل 
قاعدة البيانات!!!! 


مدخل البيانات هو ذكر كان أو امرأة يبدأ يومه وعلى يمنه أو يساره 
خو عة فة من النعامات المطلوت ذخال انها اقا عة 
البيانات» لأن الوظائف المملة يغلب عليها طابع التكرار ئممت | 
لنفس العمل ----- يبدأ مدخل البيانات بعد بضعة ساعات بالسرحان 
والتفكير بحياته ومواضيعه الشخصية والذي يدخل البيانات فعليا هو 
العقل الباطن الناتج من الخبرة!!! 


أنك كنت تفكر بموضوع ما ولا تتذكر الإشارات والانعطافات 
والشوارع... من كان يقود السيارة؟!!! 


أماذا هذا الموضع النفسي والفلسفي؟؟؟؟ 


لأنه مطلوب منك عند تصميم قاعدة البيانات ان تتقمص شخصية 
مدخل البيانات بين الحين والآخرء لماذا؟ لأنك تريد أن تحد بشكل 
كبير من حجم الأخطاء في قاعدة البيانات؟ لماذا نحد من أخطاء 
مدخل البيانات؟ لأن صاحب المشروع سيحصل على نتائج خاطئة 
وبالتالي لن يستخدم برنامجك؟ الخسارة تقع على كاهلك أنت|!!! 


الهدف الآن واضح --- آمل ذلك --- عند تصميم قواعد البيانات لا 
نريد أن يقوم مدخل البيانات بإدخال بيانات خاطئة" القاعدة العلمية 
تقول --- هذا مس 


واااا١ااااو‏ --- إذا كان مستحيلا فما العمل؟ الهدف أصبح أن تساعد 
مدخل البيانات على الحد من الأخطاء لا أن تمنعها كلياً!!! 


تتفق معي أن هذا غریب ۶ لماذا؟ لأنه من الناحية العلمية نستطيع 
أن نجبر مدخل البيانات على ألا يقوم بإدخال أي شيء خطا ومع ذلك 
القاعدة العلمية تنصح بعدم تنفيذ هذا بل فقط الحد من ذلك لا منعه !!! 
لماذا؟ لأن تكلفة المنع في تصميم قواعد البيانات عالية جدا وتفوق 
تكلفة عمل تدريب صغير لمدخل البيانات. 


كيف ولماذا نمنع؟ موضوع أخر قد نتطرق إليه فيما بعد بعد الانتهاء 


لماذا نحد من الأخطاء الناتجة عن إدخال البيانات أصبح واضحا" آمل 
الآن. 


الحاسب الال" متخلف "عفوا --- الحاسب الال یعکس فکریا ریاضیا 
لا منطقیا!! 


المنطق هو إدراك عالي جدا لا يصله إلا البشر فقطإ!! 


أقرأ معي الكلمات التالية فضلا منك: 


ماذا قرأت ؟؟؟ 

لأنك" بشر "ولديك الإدراك الذي فضلك به الحق تبارك وتعالي فإنك 
ترى أن كل الكلمات السابقة تعني أحد الجنسين من البشر وهي الأم 
والأخت والزوجة والبنت وهكذا. 


توقف - رکز -- استمر 


في مطلق برامج قواعد البيانات (كلها على الإطلاق) ومن ضمنها 
الأكسس ما سبق يعني 6 كلمات مختلفة ؟؟؟؟!!!! 


فلو کان لدبك استعلام ترید ډه ا تحصل فل إجمالي أعداد الإناث 
في قاعدة البيانات فاإنك قطعا لن تحصل غا إجابة صحيحة ؟؟؟؟!|!| 


الآن نفكر ونخطط لقاعدة البيانات --- كيف نمنع مدخل البيانات من 


إدخال حقل الجنس للإناث بطرق مختلفة؟ 


بل ليس هذا فقط؟؟؟ المطلوب منك كمصمم قواعد بيانات هو آكبر من 
هذا» المطلوب يتجاوز الحد من أخطاء مدخل البيانات إلى مسافة أبعد 
وهي المساعدة على إدخال البيانات. 


طعا ل اقصنثك المساعدة اليدوية في إدخال البيانات !!! بل في طريقة 

تصميم القاعدة لتساعده على ذلك وعندها قد تسمع ان مدخلي البيانات 
يدعون لك" وان كنت أشك في هذا لكونهم دائمي التذمر بغض النظر 
عما تعمله."!! 


إحفظ الكلمة التالية" المصطلح 1۷أ٣‏ 9 |٣]‏ "ويعني التكامل والتماسك 
اعد ة الیانات مئل ما رخا شاا هى يانات لا فة لها" ده 
تحليلها تصبح معلومات "والبيانات بطبعها عدم التماسك والتكامل 
ومن هنا لا بد الا تترك أي تغرات في قاعدة البيانات يتسلل منها 
مدخل البيانات إلى إدخال بيانات خاطئة تؤدي إلى فقد التكامل 
والتماسك لبنية قاعدة البيانات. 


¥y‏ ا" اتعني أن كافة حقول وسجلات كافة الجداول تعمل مع 
بعضها البعض بشكل متناغم وبشكل يحد من أخطاء إدخال البيانات . 
بعد کم درس راح أسأل عن لاا |٣69‏ وخلي واحد ما يجاوب صح؛ 
كال واا 

الآن عزيزي القارئ» أعد قراءة هذه الصفحة وباستخدام قلم 
الرصاص أكتب المصطلحات وأشرحها لنفسك مرة أخرىء» ليتنا 
نكتب متلما نقرأ. الكتابة هي المعلم الأول. 


أية أسئلة تقفز إلى أذهانكم --- أسألوها حتى يطمئن قلبي أننا نسير 
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بالاتجاه الصحيح. 

للحد من أخطاء إدخال البيانات نقوم بعمليات: 
المنع 

الاختيار 

تحديد النطاق 

الإكمال والإدخال والاختيار الآلي 

التأكد من أ٣‏ وما |٣‏ لقاعدة البيانات 


وكلها سنتحدث عنها فيما بعد بإذن الحق تبارك وتعالى. 


تحیاتی»›»»› 


مرحباء»» 


E ll 
بسلك.‎ 


آمل آنه يو جد هناك الان فى هده الليلة المباركة من قام فعلا بتصميم 
الجدول الأساسي لفاعدة البيانات الخاصة بالمستو صف غلم ورقة 
ببضا 

۶ .» 


آمل انه يوجد هناك من قام بإدخال 45 سجلا في قاعدة البيانات (على 
الورق) من خلال جدول رسمه بالمسطرة والقلم. 


آمل أننا نعمل سويا بهدوء وروية وتفكير وقناعة لهدف الوصول من 
ضفة شط إلى الضفة الأخرى بطريقة علمية وصحيحة وسليمة. 
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ا اون و الشات فی عدرل 
على ورقة بيضاء فرجاء لا يكمل القراءة. توقف فورا الآن. رجاء لا 
تضيع جهدي ووقتي سدی. توقف ومن تم تابع بعدما تکون انهیت 
المطلوب منك. 


صدق أو لا تصدق أن ما قمت بعمله هو قاعدة بيانات مكتملة من 
كافة الجهات 

صدقٰ E‏ 
تصمم به قواعد البيانات قبل عام 1969 a‏ 


كل ما عليك أن تفعله الآن هو أن تستمع (مع فنجان من القهوة) 
ا الى الجدول الجميل ي ا والذي E‏ 


بيانات. 


تح صفحة بيضاء جديدة وفي منتصف الصفحة" اة اومن تم 
أنقل معي هذه الأسئلة إلى الورقة: 


كم عدد الزيارات للمستوصف؟ 


كم إنثى قامت بزيارة المستوصف ودفعت أكثر من 100 ريإل؟ 
كم طبيبا في المستوصف لا ينتمي إلى الجنسية البريطانية؟ 
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كم زيارة حدثت بعد منتصف الليل؟ 

ما هو متوسط التكلفة المدفوعة من قبل الذكور؟ 

E‏ الشهري لبدل النقل للطبيبات؟ 

 ؟ايرهش‎ 

ا هو خا ل ال ك من ت 

افو اعفار ال 

كم طبيبة اسمها سميرة؟ 

كم عدد العيادات في الطابق التالث؟ 

كم عدد الزيارات من قبل المرضى الصباحية؟ 

كم عدد الطبيبات السعوديات اللاتي دخلهن السنوي أكثر من 150 
الف ربإال؟ 

كم طبيبا تواجد في عيادة في الطابق الأول وكان معه مريضا ذكرا؟ 
ما هو الدخل اليومي للمستوصف؟ 


صدقوني -- هذه قاعدة بيانات كاملة من الألف إلى الياء 


آمل الآن من الجميع وبدون عمل أي تعديل على بيانات الجدول الذي 
أدخلتم به السجلات (على الأقل 45 سجل) أن يجيبوا على الأسئلة 
السابقة ويقوموا بكتابة الإجابات في النصف الأسفل من صفحة 
اة 


صدق أو لا تصدق --- راقب كيف يتولد الإحباط والصداع وأنت تعد 
وتحاول الإجابة 

صدق أو لا تصدق --- أن ما تقوم به الآن هو تقريبا وإلى حد كبير 
هو ما يقوم به أي برنامج قواعد بيانات -- أنت الآن تقوم بدور 
الاکششن 


مر خر عندما نصل إلى القواعد والمفاهيم الأساسية لبناء نظم 
قواعد البيانات وأنت تقوم بالقراءة فقط دون تطبيق أو تقوم بالتطبيق 
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على الآكسس أو غيره -- صدقني ستعود إلى نفس ما كنت عليه قبل 
ان را هاو اام اکم ران راك هوی تف ار ا ل كت قرا 
فقط فأنت تضيع وقتك. 


قم بتشذيب أقلام اارصاص 

لدينا الكثير والكثير والكثير من الكتابة. 

الله المستعان. 

فخیاتی»»» 

مرحباء»» 

من نفذ التمرين الأول (كتابة على الورق) يمكنه الآن الإستمرار معنا. 


اا تة هر قاع اقات تح مكاة الحو ات وط رة 
التصميم هذه تسمى ءعءهطهاه0 ها۴ أو قواعد البيانات المسطحة 
وهي نفس الطريقة المتبعة في لغة C0801‏ ولا أعلم إن كانت 
00801 مازالت تتبع نفس الأسلوب حيث تركت هذه اللغة مذذ 
أكثر من 10 أعوام. 


عند وضع كافة الحقول بدون أي إستثناء في جدول واحد نحصل على 
(قاعدة بیانات مسطحة) = لا تستغرب u‏ أقول للك ا EXCEL‏ 
يوجد فيه تطبيقات متقدمة لقواعد البيانات من النوع المسطح. 


هناك ميزة كبيرة ومهمة جداً لقواعد البيانات المسطحةء وهذه الميزة 
هي أن تصميم وإنشاء وتنفيذ قاعدة البيانات يتم في وقت قصير جدا 


وقياسي» قاعدة البيانات التي قمنا بتصميمها لإدارة المستوصف 
استغرقت أقل من ساعتين وعلى الآأكسس لن تأخذ أكثر من عشر 


24 


دقائق. هذه ميزه رائعة جدا. 


تخفظ ونا قر اغد انات من الترع المح اوا هن هار 2ن 
و 6 ع ااا 


فان التطبيقات على قواعد البيانات المسطحة هي التطبيقات الى 
يراد منها عمل الإحصائيات فقط. لن أسهب في شرح هذا النوع من 
قواعد البيانات لأن إستخداماته محدودة جدا جدا وفى إطار ضيق» 
وبعد أن نستوعب النوع الثاني من قواعد البيانات ستكون الأمور 
أوضح بمشئية الله عز وجل. 


سؤال: بماذا تتميز قواعد البيانات من النوعأجا٣‏ ؟ 
سؤال: ما هي قواعد البيانات من النو عأج|۴ ؟ 


نعود إلى المستوصف» نحن الآن في قاعة إستقبال المرضى في 
المستوصف. 


يدخل المستوصف مريض: 
العمر: 42 عاما 

الإسم: محمد عبد الله 
الجنسية: سعودي 

الجنس: ذكر 

القرض: إفلرازا 


نطلب منه كافة المعلومات تم نقوم بتحويله إلى: 
الطبيب: سميرة عبد الخالق 


الجنس: أنثى 
العمر: 52 
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الجنسية: مصري 


5 


ونقوم بتوجيه المريض إلى الطابق الثاني حيث تقع عيادة الأنف 


والأذن والحنجرة. 


عند خرو ج المريض نقوم بتسجيل تاريخ ووقت الخروج والتكلفة 
المدفو عة منه. 


ما الذي حدث؟ 
تم اضافة سجل جدید في قاعدة البيانات المسطحة التي قمنا بانشائها. 


خرج محمد عبد الله من المستوصف وفي عجلة من أمره صدمته 
سيارة مسببة كسر في الساق اليمنى... 


دخل محمد عبد الله مرة أخرى إلى المستوصف وتم توجيهه إلى 


ما الذي حدث؟ --- قمنا بإاضافة سجل جديد في قاعدة البيانات 
الخاصة بالمستوصف 


لدی خروج محمد عبد الله وذهابه إلى البيت قدمت له زوجته عشاء 
أتعب معدته فنقل بسيارة الإسعاف إلى المستوصف مرة ثالثة. 


دخل محمد عبد الله (المسكين) إلى المستوصف مقدما بيانته السابقة 
مرة أخرى وتم تحويله إلى عيادة الأمراض الباطنية. 


ما الذي حدث؟ قمنا بإضافة سجل جديد إلى قاعدة بيانات 
المستوصف. 
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لنترك المسكين محمد عبد الله قليلا ونذهب إلى صديقنا مدخل البيانات 
في قاعة الإستقبال ونسأله عما فعل الليلة. 


کچ هذه الليلة قام مدخل البيانات بادخال ثلانة سجلات» بماذا تمیزت 
هذه السجلات؟ 


تميزت بان أحد عناصر قاعدة البيانات وهو (المريض) قد تكرر 
تسجڊا » بیاناته ثلاث مرات 


ماذا يعني هذا؟ 


أنه عند تكرار دخول المريض للمستوصف أكثر من مرة يتطلب 
الأمر في كل مرة إدخال كافة بياناته كاملة. 


أنه عند تكرار إستخدام الطبيب (متل أن يدخل خمسة مرضى على 
طبيب العظام) يتطلب الأمر إعادة إدخال بيانات الطبيب مرة أخرى. 


أنه عند تكرار إستخدام أي عيادة (مثلا عشرة مرضى تم علاجهم من 
قبل ثلاثة أطباء كلهم في العيادة الباطنية) يتطلب الأمر إعادة إدخال 
كافة بيانات العيادة. 


في قواعد البيانات المسطحة يتم إعادة إدخال بيانات أي عنصر يتكرر 
أكثر من مرة. 
الآن سأذهب لشرب فنجان من القهوة وأتمتع بقليلا من التمر... 


وعندما أعود بعد بضعة دقائق أتمنى من الجميع أن يكونوا قد فكروا 
في إجابة السؤال التالي. 
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ما هي المشكلة من تكرار إدخال البيانات؟ 


تحیاتی› ¢“ 


مرحباء»» 

توقفنا عند السؤال التالي: 

ما هي المشكلة من تكرار إدخال البيانات؟ 
الجواب: مشاكل جمة لا عد ولا حصر لهاإ!!! 
أهم هذه المشساكل: 


نکر ار انات مو خو دة ااا 

إستنزاف شديد للسعات التخزينية متل الأقراص الصلبة 

موطن خطير لإرتكاب الأخطاء الناتج عن التكرار فمتلا المسكين 
محمد عبد الله في الزيارة الثانية تم تسجيل إسمه على شكل (محمد 
عبدالله) بدون مسافة بين التعبيد ولفظ الجلاله وبهذا يصبح لدينا 
مریضا جدید!!! 

أما المشكلة الأكبر هى عند إضافة حقل جديد لقاعدة البيانات» متلا 
إضافة تاريخ الميلاد للمريض !!! يتطلب الأمر الآن إدخال نفس 
التاريخ في كافة السجلات فإذا كان لدينا 500 زيارة منها 42 زيارة 
للأخ محمد عبد الله يتطلب الأمر إعادة إدخال تاريخ الميلاد 45 مرة 
!! 


تكرار ادخال البيانات هو أحد مصائب ولیس مشاكل قواعد البيانات 
المسطحة وكانت مرتعا خصبا للأبحاث في قبل عام 1970 ميلادية. 
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العالم الخطير السيد ©5 60 والذي يعمل في شركة 8| قام في 
عام 1969 ميلادية بطرح أول نظرية تقوم بعلاج مشاكل قواعد 
البيانات المسطحة |۴ وتم تسميتها قواعد البيانات العلاقية 
Relational Databases‏ 


صدق أو لا تصدق» مازالت هذه النظرية هي المعمول بها في كافة 
برامج قواعد البيانات الموجودة في العالم الان وطبعا من ضمنها 
الأكنس. 


نظرية هذا العالم تتكون من 12 قانون كل واحد من هذه القوانين 
يتطلب محاضرة خاصة»› أي نحن بحاجة إلى 12 محاضرة على 
الأقل لشرح هذه القوانين»› ولكن لضغط الوقت ولعدم رغبتي في 
الإسهاب في الجزء النظري بل أريد أن رکز على التطبيق العلمي 
الأسس العلمية لقواعد البيانات. 


إن القوانين التي وضعها هذا العالم (الذكي جدا طبعا) تم تبنيها من 
قبل الشركات العالمية وبدأت تنتج برامج تعتمد على هذه القوانين 
وتتيح هذه البرامج لمستخدميها بتصميم قواعد بيانات علاقية 

ا2 Relation‏ ولصعوبة هذه القوانين يكفي أن تعلم عزيزي القارىء 
أن أفضل قاعدة بيانات تم تصميمها في العالم إلتزمت ب 8 قوانين 
فقط من 12 الأصلية!!! 


ا ن اکر ی درا دا ات س اراک واک 
CODD.‏ 


قبل الخوض في قواعد البيانات من النوع العلاقي اج 0ااجامR‏ 
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نقول التالي: 


أن قواعد البيانات من النوع اج ههام8 تقول بحل كافة مشاكل 
قواعد البيانات المسطحة بل تؤدي إلى) |٣69٣‏ مين يذكر هذا 
البيانات. 


ولكن الثمن المقابل لهذا الميزات غير رخيص!!!! 
فقواعد البيانات من النوع العلاقي: 


لا يمكن إنجازها من قبل شخص واحد مثل تلك المعمولة بالنوع 
المسطح» هذه تحتاج إلى فريق عمل. 

أن إنشاء قواعد البيانات وتصميمها بالشكل العلاقي اا بعدة 
مراحل من النوع المسطح وتتطلب تخطيطا وفكرا وإستراتيجية 
واضحة. 

أن التكلفة المدفوعة في تصميم وبناء قواعد بيانات علاقية أكبر بكثير 
من تلك المدفوعة في المسطحة»ء ولكن الثمن يتم تعويضه من خلال 
اختزال تكلفة الصيانة والتطوير لفاعدة البيانات. 


لا يوجد نوع آخر لقواعد البيانات في العالم غير هذين النوعين: 
مسطح ۴|4 ذي تكلفة منخفضة في التصميم وتكلفة مرتفعة في 
الصيانة والتطوير ويعاب عليه تكرار البيانات التي تؤدي إلى رفع 
تكلفة التخزين وبطىیء البحث والإسترجاع والإستعلام وغيره. 
علاقي Relational‏ ذي تكلفة مرتفعة کی التصميم وتكلفة منخفضة 


الصيانة وال يعاب عليه ية الت التى تحتاج |١‏ 
في و ير وډ صعوڊ ج 
رک کک وک ی د 
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تحیاتی›۰» 


مرحباء»» 
اذا كنت تريد عمل قاعدة بيانات: 


أنت المصمم لها 

أنت المستخدم لها 

أنت مدخل البيانات 

أنت من سيقوم بعمل إحصائيات وتقارير سريعة 
انت تحت ضغط الوقت والتكلفة 


مسطح .۴|۵1 لا تنس آنه لا يوجد فروق إطلاقا بين البرامج كل ما 
نتعلمه هنا ینطبق علی: 


Access 

FoxPro 

Dbase 

Clipper 

Microsoft SQL Server 
Oracle 


LECE a غ‎ a a 
أن يكون عدد السجلات صغير نسبيا مثل عدة آلآف.‎ 


آما... 
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إذا كان مدخل البيانات يختلف عنك بصفتك مصمم لقاعدة البيانات 
أو أن القاعدة ستستخدم من قبل آخرين -- تريد بيعها في السوق متلا 
أو ربطها بموقع على الإنترنت 

أو أن لديك متسع من الوقت 

أو لديك فريق عمل 


أو ريد أن تصمم القاعدة وفق الافس العلمية والصحيحة لقواعد 
البيانات فيجب أن تقوم بالتصميم على أسلوب اج ههام8 العلاقي 
وبتطبيق قو انين السيد0 ©٥005‏ 


ماذا يقول مستر 5050 °00 وسنبسط هنا (من يريد القوانين الفعلية 
يطلبها لإرسالها له ولكنها بالأسف باللغة الإنجليزية وتتطلب إحترافا 
في الإنجليزية وفي قواعد البيانات لترجمتها) أرغب ممن سيطلبونها 
ألا يقزموا بترجمتها حتى لا يوقعوا من يقرأها باللغة العربية في 


قلنا أننا سنبسط قوانين مستر C000‏ والتبسيط له قوانين أيضا حيث 
أرغب ممن يقرا ألا يقوم بالعد للحصول على 12 قانون لأننا قد 
نبسط قانونا واحد بقوانين متعددة أبسط وأسهل. 


قبل الدخول في قوانین مستر C0050‏ سأطرح قوانين مستر 
aster‏ l|nternetMء‏ بالمناسبة هذا هو محدٹکہ!!! 


لا تستخدم اللغة العربية في كل مما يلي. 
اسم قاعدة البيانات 

أسماء الجداول 

انشام الحقول داخل الجداول 
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عند التسمية لكل ما سبق إستخدم الأحرف اللاتينية (اللغة الإنجليزية) 
والآن ركز معي بشدة --- لا تضع مسافات بين أي إسم لكل ما سبق 
جدول الأطباء ماج آءإهامم لاحظ أن الحرف الأول من كل 
كلمة كبير ولا يوجد هناك مسافات. 


طبعا إتفقنا على أنه لا يوجد شيء یسمی نماذج وتقارير ومایکرو 
وغیره (مثل ما في الأكسس) هده تبسیطات للاستخدامات المحدودة 
جدا والتي لا ترقى إلى التطبيقات التي يتطلبها السوق !!! وعليه 
سننسى أنه يوجد نماذج وتقارير وما إلى ذلك من السخافات لأنها 
مش ارت اله ران نض ك ل مرا مود درا 
البيانات 


کل ما لدینا (حسب ما قلناه سابقا) جداول وإستعلامات فقط (حتی 
تاريخه طبعا) وهي كلها موجودة في الطبقة الثالثة (من يتذكر الطبقة 
التالتة؟) وأين توجد؟ 


انتهت قوانيني !! لنعود إلى مستر 0000© 

ما هي قوانینه؟ 

كل وحدة متماثلة من وحدات قاعدة البيانات توضع في جدول مستقل 
بذاته يعبر عن محتويات هذا الجدول. متال جدول المرضي لا يحتوي 
أية بيانات إلا عن المرض فقط وهو وحدة مستقلة بذاتها. ينطبق نفس 
الو غل ا اول اخرى 

في الجدول الواحد لا يسمح بأي تكرار للسجلات» بمعنى أنه عند 


إدخال معلومات طبيب متلا في جدول الأطباء يمنع تكرار بيانات هذا 
الطبيب مرة أخرى. 
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لا بد من تمييز كل سجل في الجدول بحقل مميز (ويفضل أن يكون 
حقلا واحدا فقط) ويسمى مفتاح الجدول. في الآكسس مثلا يسمى 
Primary Key‏ 


بيانات حقل المفتاح الرئيسي لا تتكرر لأي سجل. أي أن كل سجل 
يحتوى على بيانات مختلفة في المفتاح الرئيسي أو الأساسي سمه ما 


نللا , 


لا يسمح لبيانات حقل المفتاح الرئيسي أن تكون فارغة أو غير 
ا 


نستكمل بعد فنجان من القهوة. 
تحیاتی»»» 
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مرحباء»» 


أعتذر لطول فنجان القهوة لإستقبالي بعض الضيوف» وحقيقة يبدو أن 
الشف تعر با اهم فى عا خر "ق اع الات "رما اله من 
عالما!! 


ما زلنا نبحر مع السيد C050‏ في قوانينه الخاصة بقواعد البيانات 
العلاقية: 


نفتح في الدفتر صفحة جديدة ونبري قلم رصاص وتعالوا بنا نعيد 
تصميم قاعدة البيانات خطوة خطوة ة (على الورق طبعا) مع إعتبار 
لقو انين العالم0 °05 


لدينا فى مشروعنا الخاص بادارة مستوصف ثلاثة عناصر مختلفة 
وحسب القوانين لا بد لكل عنصر أن ينفرد بجدوله الخاص وعليه 
للم رضي و القاني للأطباء و لقانت للعيادات. 


أريدك عزيزي القارئ الآن أن تركز معي بشدة: 
تخيل أن كل جدول من الجداول الثلاثة يحتوي على 500 حقل!! 


إتفقنا؟ هذا التخيل في غاية الأهمية حتى نفهم أول القوانين والأسس» 
لادا نشخيل هذا؟ 

لسبب بسیط جدا (سنستوعبه بشکل اکبر فیما بعد) وهو أن عدد 
الحقول في أي جدول لا قيمة له حالياً !!! لماذا ليس له قيمة حاليا؟ 
لأننا في قواعد البيانات العلاقية لا نهتم لوصف الجدول بل نهتم 
لرک ال لی وکو عل ا غ کک 


lلnصطntegrityzİ|‏ ؟ 


إذا الهدف هو تماسك وصحة بناء القاعدة وليس وصفها وتصميمها 
حالیاء وبناء عليه أطلب مناك عزيزي القارىء الآن أن تغمض عينيك 
-- خذ نفسا عمیقا -- زفیر ر -- إفتح عينيك بهدوء وتخيل معي ثلاثة 
جداول أساسية كل ل يصف جزئية واحدة محددة وكل جدول 


يحتوي على 500 حقل. 


35 ۰*٩ + 
إتفقنا؟‎ 


مرحباء»» 


الآن صفحة جديدة بيضاء (في الدفتر) -- في منتصف الصفحة -- 
قاعدة بيانات الآباء والأبناء. 


دعك من المستو صف الاآن. 

تريد ان تنشاً قاعدة بيانات توضح الأباء والأبناء في عائلتك. حسب 
قوانین 0K00‏ لدینا جدولین وکل جدول فيه مفتاح رئيسي. 

دعنا نتفق... 


عندما قول برامج قواعد بیانات فأنا أقصد آكسس و ا8۵وأوراكل 
وغيرها 

عندما أقول قاعدة بيانات فأنا أقصد تلك التي تقوم أنت بتصميمها 
باستخدامك لأي من البرامج المشار إليها أعلاه. 


م ی لي اوال اللي هل قوانین 6K00‏ للبرامج آم 
للقواعد؟ ب بمعنى آخر هل هي لشركة ميكروسوفت حتى تعطينا برنامج 
آکسس جید ام هده القوانين لك أنت عند تصميمك لقاعدة البيانات؟ 


ماذا يعني هذا؟ ببساطة وركز معي بشدة أنك عندما تضع حقلا أساسيا 
e OT‏ 
Em‏ 


لدينا في هذا التمرين جدولين واحد للأباء والآخر للأبناء: 
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جدول الآباء 


رقم الأب -- حقل رئيسي 
إسم الأب 
عمر الأب 


جدول الأبناء: 

رقم الإبن -- حقل رئيسي 
إسم الإبن 

عمر الإبن 


اللآن في صفحة جديدة إرسم جدولا بالمسطرة وقلم الرصاص (رجاء 
للمرة المليون على الورق) حتى نفهم سوياء وسمه جدول الاباء 
وأدخل البيانات التالية وهي مرتبة رقم الأب إسم الأب عمر الأب 
2 خالد سعید أحمد 32 

7سمير حسين الأحمدي 63 

N1ءمحمد‏ أحمد عبد القادر 36 
أجب عن الأسئلة التالية. 


81سمير حسين الأحمدي 63 --- ماذا يحدث؟ 


من لم يعرف الإجابة أقترح عليه أن يبدا مرحلة إعادة القراءة مرة 
اخری بترکیز اعلی 


نجيب فيما بعد بإذن الحق تبارك وتعالى. 


تحیاتی»›»» 
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مرحباء»» 


ماذا يحدث عند إضافة سجل جديد في جدول الأباء بالبيانات التالية: 
871سمير حسين الأحمدي 63 --- ماذا يحدث؟ لن يحدث شيا 

سجل جديد لا غبار عليه حتى وإن تشابه الإسم (وهو خطأً أيضا) 

لكنه غير مهم حاليا -- لا تنس الهدف وهو تماسك قاعدة البيانات. 


1سامي مطلق الدوسري 51 -- ماذا يحدث؟ هذا يخالف أحد 
قوانين مخترع قواعد البيانات العلاقية السيد K0‏ والذي ينص 
على منع بل إستحالة تكرار المفتاح الأساسي لأكثر من سجل واحد. 
السؤال البديهي لماذا يمنع من تكرار 901 في سجلين مختلفين؟ أو 
بعبارة أخرى» لماذا لا نستطيع تكرار بيانات المفتاح الأساسي؟ والآن 
نبداً في التركيز مرة أخرى. ملاحظة -- إذا وجدت برنامج قاعدة 
بیانات (وان شاک في هذا) يسمح ا هذا e‏ ۳ 

برامج غ البيانات ا صلة» لكن اذا استخدمت راک قدیما 

صمم قبل 1970 ميلادية فقطعا سيسمح لك لأن كل برامج قواعد 
البيانات قبل هذا التاريخ کانت. ۾ |۴ 


يستكمل معي ذووي الأقلام والبريات والذين كتبوا فقط!!! 


صحيح أن K05D‏ نظم لنا قاعدة البيانات من خلال فصل الوحدات 
الأساسية في جداول مختلفة ولكنه خلق لنا مشاكل جمة لتصميم 
القاعدة» تذكرون طبعاً أن تصميم قواعد البيانات العلاقية أصعب 
وأعقد من تلك المسطحة.†م|۴ 


ما هو الهدف من قاعدة بيانات الآباء والأبناء؟ 

هو الحصول على تقرير أساسي يتم فيه سرد الأبناء لكل أب نختاره 
فمثلا عند إختيار سامي مطلق الدوسري من قاعدة البيانات تقوم 
القاعدة بسرد كل الأبناء اللذين يقولون لسامي (بابا.( 
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من يشعر معي أنه يوجد هناك مشكلة الآن؟ حيث أن كافة الأبناء 
موجودون في جدول مختلف . ... ممممممممممم --- من هنا جاءعت 
كلمة قواعد البيانات العلاقية أن ك غلاق ما ين الحذارل وها 
قانون من قو انین. 0005© 


مختلف لا بد من الوصول لهذه البيانات عن طريق علاقة ما. 


كلام كبير» ما يعني؟ للحصول على الأبناء التابعين لأب ما يتطلب 
الأمر إنشاء (علاقة) بين الجدولين. 


في جدول الآباء الحقول التالية: 
رقم الأب -- حقل رئيسي 

إسم الأب 

عمر الأب 


وفي جدولالأبناء يوجد الحقول التالية: 
رقم الإبن -- حقل رئيسي 

إسم الإبن 

عمر الإبن 


لنفترض أنه يوجد في جدول الأبناء 8 سجلات» كيف نعرف أن 
السجل الثالث هو أحد أبناء خالد سعيد أحمد الموجود في سجل 
الآباء؟؟ 


نعود ونسأل مستر 6K00‏ » بعد تفكير عميق وبضعة فناجين من 
القهوة يرد علينا هذا العالم ويقول لنا E‏ 
رکكززززززززززززززززززززززززززززز --- إستخدم (الحقل 


الغريب)؟؟؟ 
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سأسألكم عن ما هو الحقل الغريب فيما بعدء فلنركز جيدا ولنستغل 
الدفتر الذي أمامنا وأقلام الرصاص للكتابة والتركيز -- لا تنسوا أن 
الهدف تماسك قاعدة البيانات وليس الحقول والإستعلامات» نحن في 


مرحلة مبكرة من التصميم. 
ممفمممممح 


Foreign Field الحقل انئغريب‎ 


ماهو ؟ 
الحقل الغريب هو: 
الجدول؟ 


لا يمكن أن يكون مفتاحا رئيسيا في الجدول الذي ينشاً فيه 
يجب أن يوجد ما يشابهه في جدول آخر 

يجب أن يكون مشابها ومطابقا ونسخة مقلدة بالضبط من الحقل 
الأساسي في الجدول الآخر 


واااو صداع.... تعالوا نبسط هذه الجمل أكثر وبروية وبهداوة ومع 
فار و وا ران ار ٤ا‏ 


أين المشكلة هل هي في جدول الآباء أم في جدول الأبناء؟ 
الإستنتاج المنطقي أنها في جدول الأبناء لماذا؟ 

لأن جدول الأبناء يسسمى جدولا غير مستقر لماذا؟ لآنه يحتوي على 
بيلنات متماسكة وغير منتميةء ماذا يعني هذا؟ لنفكر قليلا. 


في جدول الأبناء 8 سجلات» إذا نظرنا إلى هذا الجدول نرى أنه 


متماسك ومتناغم ولکن تکمن مشکلته في انه لا یدلنا على من أب هذا 
وأب هذا. 
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طالما أن المشكلة في جدول الأبناء إذا الحقل الغريب يجب أن يكون 
في جدول الأبناء؟ 


من لم يستطع أن يستنج هذا معنا (أن الحقل الغريب يجب أن يكون 
في جدول الابناء) فاقول له لا تغضب.. ماشي» سنعید شرح هذه 
الجزئية بعد قليل مرة أخرى من زاوية مختلفة. 


يكون مفتاحا رئيسياًء هذه نقطة في غاية الأهمية لشخصية الحقل 
الغريب. إذا رقم الإبن لا يصلح» وحقيقة القول لا تضيع وقتك في 
البحث عن الحقل الغريب في جدول الأبناء لأنه لو كان هذا الحقل هو 
ماک الحقول الموجودة فعلا في جدول الأبناء لما صار غريبا» 
ونحن نبحث عن حقل غريب أي لا يمت لجدول الابناء باي صلة. 


من آين نأتي بهذا الحقل الغريب؟ الجواب هو أن الحقل الغريب 
موجود دائما وأبدا کي الجدول الذي تريد أن تنشاً معه العلاقة. 


لنعد إلى مشكلتنا وهي كيفية تحديد الأبناء الذين ينتمون إلى أب واحد 
نحن نبحث عن الأخوة والأخوات. إذا نريد من جدول الأباء حقلا 
الأبناء ويساعدنا على إتمام إنشاء العلاقة. 

هذا الحقل هو رقم الأب من جدول الآباء. 

عند إستلاف رقم الأب من جدول الآباء ووضعه كنسخة مطابقة في 
جدول الأبناء» يصبح هذا الحقل أساسيا في جدول الآباء وغريبا في 
جدول الأبناء. 
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أصبح جدول الأبناء كما ل 
رقم الإبن -- حقل رئيسي 
إسم الإبن 

عمر الإبن 

رقم الأب 


لنعد إلى شروط مستر K0‏ الحقل الغريب يجب أن يكون مطايقا 
ونسخة مشابهة لتلك الموجودة في الجدول الأساسيء أي لو کان رقم 

الأب في جدول الآباء عبارة عن 6 خانات وعلى هيئة أرقام فيجب أن 
يكون كذلك في جدول الأبناء. 


لاحظ الآن وبتركيز شديد أنك لو قمت قمت بإضافة 8 سجلات في جدول 
الأبناء انك ستواجه حقلا غريبا موجودا في جدول الأبناء ويتوجب 
عليك أن تضع فيه بيانات حيث لا يمكن أن يكون فارغا. 


ار 


ما هو تعريف المفتاح الرئيسي؟ --- أين المجيبون؟ الووووو 
سابقاء أي أنه في جدول الآباء لا يوجد أي سجل بدون رقم للأب. 


قانون للسيد: 0 °00 1 

لا يمكن للحقل الغريب أن يكون فارغاء من يقول لي لماذا؟ 

لا يمكن للحقل الغريب أن يكون مفتاحا رئيسياء من يقول لي لماذا؟ 
محتويات الحقل الغريب يجب أن تطابق بيانات موجودة أصلا في 
الجدول الذي تم الإستعارة منه., لماذا؟ 


وين الصاحيين معي؟؟؟ !!!هيا للأجوبة على الأسئلة الثلاثة السابقة: 
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فرضا تركنا السجل الرابع في جدول الأبناء بدون استكمال الحقل 
الغريب» ما هي المشكلة؟ المشكلة ان هذا الإبن لن يتم معرفه أباه 
ومن هنا جاء المنع بترك بيانات الحقل الغريب فارغة» بعبارة أخرى 
لن يسمح لك بترکه فارغاء لابد من إدخال قيمة ما. 


لماذا لا يكون الحقل الغريب (رقم الأب) في جدول الأبناء مفتاحا 
رئيسيا؟؟؟ هيا عاد هذي سهلة شباب» لأن من خصائص المفتاح 
الرئيسي هو عدم التكرارء فإذا جعلنا (رقم الأب) في جدول الأبناء 
مفتاحا رئيسيا فلن نستطيع تكرار الرقم 1 وبهذا لن نستطيع آن 
نجعل لمحمد أحمد عبد القادر أكثر من إبن واحد» واضحة؟ 


السؤال التالث سخيف؟ لا بد ان تستطيع الإجابة عليه !إإإتغيير طول 
الحقل الغريب عما هو في الجدول الذي أستعير منه سيخلق مئات 
المشاكل. 


لنعيد شرح الموضوع برمته مرة أخرى !!إوسأسمح الأن بإستخدام 


إفتح الآكسس وقم بإنشاء قاعدة بيانات جديدة وسمها ¥اأ ”۴4 إتفقنا 
سابقا أن كل التسميات باللغة الإنجليزية. 


قم بأنشاء جدول إسمه 16۲5 ج۴ وبه الحقول التالية: 
ex - 4 --‏ --۴atherNumمفتاح‏ رئیسي من نوع نص وبطول 
4 خانات 
FatherName- Text‏ 
FatherAge--Number‏ 
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نشط الحقل ۴an ٥۲ un‏ وإجعله Primary Ky‏ أي مفتاحا 


قم بأنشاء جدول إسمه 60۸8 وبه الحقول التالية: 

0NN um-- Number --‏ مفتاح رئیسي 
SonName- Text‏ 

SonAge--Numbe 

۴atherN um -- Number --‏ هذا ھو الحقل الغریب 


نشط الحقل Nun‏ ° $0 وإجعله 6y‏ "|۴1 آي مفتاحا رئیسیا 
بالضغط على المفتاح بشريط الأدوات» إحفظ الجدول وأغلقه. 


من يقول لي ما هو الخطأ الفادح في تصميم الجدولين السابقين؟؟؟!! 
فكر قبل قراءة الجواب؟؟؟ 


الجواب هو الحقل الغريب ۳0ں ۲N٥طج۴‏ في جدول الأبناء نوعه 
Numb‏ ينما في الجدول الذي استعیر منه هو ۲٥×‏ بطول 4 
خانات وهذا مخالف للأسس والقوانين. 


عد مرة أخرى وقم بتعديل الحقل الغريب في جدول الأبناء ليصبح 
علی شکل ٦٥×‏ وبطول 4 خانات. 


الآن إفتح جدول الأباء وادخل البيانات التالية في السجل الأول: 
أدخل الإسم فقط: محمد أحمد عبد الله ثم إنتقل للسجل الثانيء ماذا 
حدث؟؟ نعم ظهرت رسالة خطأء ما هي هذه الرسالة ولماذا ظهرت؟ 


مین يجیب؟؟؟ 


هذا أحد قوانين المفتاح الرئيسي: لا يمكن للمفتاح الرئيسي أن يكون 
قيمة فارغة»ء لابد من وضع قيمة ما فيه. 
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إسمح السجل الأول وقم بإضافة البيانات التالية: 
0»محمد سعید أحمد 42 

0خالد عبد الله الصيعري 61 
0سعیيد محمد المالكي 32 

0ئطلال عبد العزيز المسبحي 29 

0 سمير خالد الجار الله 46 

أحفظ الجدول. 


إفتح جدول لآبناء وأدخل السجل التالي: 
0خالد 9 -- إترك الحقل الغريب فارغا 


مادا حدث؟ مین يجيييييييییییییییييب؟؟؟ واااووووووووو لم يحدث 
شيء» ولكن هذا ينافي قواعد السيد 0K00‏ حيث يقول ان هناك 


شروط: 1 

لا يمكن للحقل الغريب أن يكون فارغا 

يجب أن يحتوي الحقل الغريب على قيمة موجودة في الجدول الذي 
أستعير منه 

ولكن لم يظهر خطأء لماذا؟؟ 

الجواب: لأننا لم نقم حتى تاريخه بإنشاء العلاقة بين الجدولين. 
نفعل هذا بعد بضعة دقائق بإذن الحق تبارك وتعالى. 

تحياتي»۰۰ 


مرحباء»» 


في هذه الحلقة سأخرج عن الموضوع برمته قليلاً ونعود إليه في 
الحلقة التالية بإذن الله 
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لماذا أقوم بهذا الجهد؟ السبب وبساطة شديدة هو الحصول على أكبر 
كم من الدعوات الصادقة في هذه الليالي الفضيلة. لا اطمح ولا ابحث 
عن شيءَ آخر. 


وقد توقعت أن أجد الآلاف ممن يقرأون هذا الموضوع وهذا لم يتحقق 
بعد بالنظر إلى عدد القراء» ورغبة مني في أرفع هذا الرقم إلى 
الآلاف بل عشرات الآلاف إن أمكن هذا للحصول على دعوات 
صادقة أكثر فقد قررت بعد الاتكال على الحق تبارك وتعالى أن اجعل 
مسابقة لكم لها جائزة قيمة آمل أن تنال إعجابكم. 


وحيث ن الوقت يداهمني حتى 15 أو 20 رمضان سأحاول أن نهي 
هذه الحلقات بأسرع وقت ممكن دون الإخلال بقيمتها أو محتوياتها. 


ماهي المسابقة؟ وأتمنى من القائمين على هذا الموقع المساعدة في 
تنظيمها ووضع الشروط المناسبة لها. 


المسابقة هي تصميم قاعدة بيانات لإدارة مدرسة وحيث أنني أحاول 
ما أستطعت أن أعمق المفاهيم الصحيحة لقواعد البيانات فالمشروع 
سيقتصر على الجداول وعلى الإستعلامات فقطء حيث ستكون 
الإستعلامات هى الإجابة على عشرات الأسئلةء ولإتاحة الفرصة 
للأخوات المشاركات في هذا الموقع فقد قررت بعد الإتكال على الله 
أن يكون هناك جائزتين واحدة لأفضل تصميم من مشارك في الموقع› 
والأخرى لأفضل تصميم من مشاركة في الموقع. وطبعا الجائزتين 
متشابهتين. 


الجائزة هي واحدة لمشارك وأخرى لمشاركة: 
حجز نطاق بإسم الفائز والفائزة حسب اختيارهم (ولا يكون محجوزا 


قبلهم) 
اة النظان ر الفو فة غل الخاتم الر تسى الكاضن شر كى في 
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الولايات المتحدة لمدة سنتين 

سعة تخزينية للموقع 350 ميجا بايت 

عدد غير محدود من قواعد البيانات sوعمع٥A‏ بطاقة تخزينية من 
ضمن 350 میجا بایت 

عدد غير محدود من قواعد البيانات ا@1/S‏ بطاقة تخزينية من 
ضمن 350 میجا بایت 

سعة تخزينية بطاقة 50 ميجا بايت لخادم قواعد بيانات Microsoft‏ 


SQL 2000 

المساعدة في إنشاء الموقع مع المساعدة بكيفية ربطه بالآكسس وال 
SQL‏ 

منتدي مشابه لهذا المنتدى طبعا لأية مواضيع أخرى يختارها الفائز 
والفائزة 


عدد غير محدود من صناديق البريد الإلكتروني 

قائمتين للتحكم واحدة بالمنتدى والأخرى بالخادم 

المساعدة في تصميم الموقع (بدون إخلال بالدين والتقاليد والعادات 
الخادم من النوع المتقدم جدا أي انه یتقبل کل تطبیقات ,اB °٥0‏ 
Visual Interdev, Visual .Net‏ ,gFrontPageمl‏ ال 
ذلك. 

الكثير من الخدمات الأخرى على الخادم 


کل ما )ج افا(لافضل تمي من 
رجل وأفضل تصميم من إمرأة. ولكن لمدة سنتين فقط, بعد إنقضاء 
السنتين يقفل الموقع ويلغى كل شيء إلا إذا ارتأى صاحب الجائزة 
الإكمال بسعر 275 ربإل شهريا. بإختصار فإن كل جائزة عينية تصل 
قيمتها إلى 275 × 24 شهر اي 6600 ربإل سعودي أي أن 
الجائزتين بقيمة 13200 ربإال سعودي. 


لیس هذا فقط بل أن الفائز والفائزة سأتيح لهم المشاركة من منازلهم 
في واحد من أضخم مشاريع قواعد البيانات في المملكة العربية 
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التكاليف المدفوعة لهم مقابل عملهم. 


ا ر ن ا 
والجنسية والجنس (الهدف هو تكثير العدد للحصول على دعوات 
أكثر لشخص يفتقر إلى رحمة الله ومغفرته ورضوانه) 


يمكن تصميم القاعدة إما بالأكسس أو2000 S۵)‏ 


الآن ولإحقاق الحق وخشية أن يبدأ الهواة بالإتصال بمحترفي قواعد 
البيانات ليقوموا بتصميمها نيابة عنهم فأقول: 


ليس الهدف هو الفوز بالجائزة ؟؟؟ الهدف هو أن تتعلم قواعد البيانات 
وباالمقابل تدعو لي. 

إن تصميم تصميم قاعدة البيانات من قبل محترف بإسمك أو نيابة 
عنك هو ظلم للآخرين وإجحاف بحقهم وبحقهن وعليه وعليها أن يتقيا 


الله . 

أن يتيح المحترفون الفرصة للآخرين للقراءة والسؤال والفهم وهذا هو 
الهدف من الجائزتين» ولدي القدرة بمشيئة الله أن أعرف من تصميم 
القاعدة أن من قام بتصميمها هو من المحترفين أو المبتدئين. 


إضافة إلى ما سبق سيتم توجهيه 30 سؤالا شفويا بإستخدام الماسنجر 
مثلا للمشاركين للتاكد من فهمهم للموضوع. 


E 


لتعميق المصداقية فإن الجائزة لن تنحى إلا إذا لم يشترك أحد !!! أي 
انه لو قام شخص واحد فقط بتقديم القاعدة سيفوز بغض النظر عن 
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تصميمه أو تصميمها!!! 


أي لو قام بالتعديل وإعادة الآرسال قلن يلتفت له حتى لا يكون لدينا 
إرسال المشاركات في 29 شوال حسب تقويم أم القرى حتى لا 
يضطر أحد للتعديل. 


كافة المشاركات في المسابقة ترسل إلى 

arabservers.net‏ @®inf0ولا‏ توضع هنا وسأقوم بمشیئة اللہ 
بإدراج إسمي الفائز والفائزة هنا. 

آمل من الأخوة المتابعين معنا وكذلك القائمين على هذا الموقع تنبيهي 
لأية شروط آأخرى لهذه المسابقة وبالذات كيفية منع المحترفين من 
المقاركة زالضفظط ليم قرت افرضة الاخرين الاين ,كاك 
منع المبتدئين والتائهين من إستخدام محترفين ليصمموا لهم القاعدة. 


أسئلة المسابقة والتصميم في الحلقة القادمة بمشيئة الله. 
ملاحظة هذه المسابقة تم طرحها في عام 3 سنة كتابة الموضوع 
ال ع ال ماعا ج سا ا خان رة واا 
تحياتي»۰۰ 

مرحباء»» 

لا يشترط أن تكون الأسماء معروفة ولن يحبذ جدا لأن العملية مع 


مرور الوقت تتفاقم في التعقيد خذ مثال أنني وأنت قمنا بتصميم قاعدة 
بيانات وأسماء الجداول فيها ...,©,۸,8 وهكذا. 
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ماذا يحدث عندما تصبح قاعدة البيانات فيها 150 جدول؟ 
كيف نفرق بين الجداول واحد أسمه ۸30 والآخر 109 والحقول 
فيها 68 و 9ل العملية ستتعقد بشكل كبير جدا. 


ما هو الحل لمن لديه عوائق في اللغة الإنجليزية؟ 


الحل هو من 3 خطوات: 

الأولى وهي نصيحة عامة للجميع -- هذه فرصة جيدة لتعلم بعض 
اللغة -- قرر بينك وبين نفسك البدء في تعلم كلمات من اللغة 
الإنجليزية ولو بشكل مبسط... صدقني هي لغة تافهة جدا جدا جدا 
وان ها قل كر و كنا لاف خلا وهه لاتا وداه 


الثانية: إحصل على قاموس عربي-إنجليزي وليس العكس بحيث 
دار ا ار ف ره اول ا 
باللغة الإنجليزية. 


الثالثة: إستخدم |٥050 ۷0۲١‏ الوورد الذي يأتي مع الأوفيس 
تحت قائمة الأدوات إختر اللغة ثم الترجمةء يمكنك إختيار الترجمة 
من اللغة العربية للإنجليزية » بعد هذا إكتب كلمة (أب) مثلا ستحصل 
على ترجمتهاا ماج۴ » إفتح صفحة جديدة في الدفتر وأكتب الكلمة 
0 أو 15 مرة وأحفظها عن ظهر قلب. 


إذا فعلت هذا يوميا مع 10 كلمات فقط في نهاية الشهر سيكون لديك 
ما يقارب 300 كلمة إنجليزية........... صدقني في اللغة الإنجليزية 
وللاستخدامات المتعددة جدا لن تحتاج لأكثر من 1500 كلمة -- لغة 
ضحلة جدا أي أنه في بضعة شهور سيكون لديك مجموعة ضخمة 
من الكلمات الإنجليزية التي تكفيك لكل إحتياجات البرمجة والتصميم 
بل صدقنى ستكون بعدها قادرا على قراءة الكثير من الصفحات باللغة 
الإنجليزية. 
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تحياتي»۰۰ 
مرحباء» 


بعد ساعتين ونصف على العمل في أسئلة المسابقةء وجدت أن اقوم 
بتأجيل الأسئلة إلى الغد لأخذ مزيدا من الوقت. فعليه ستکون اسنا 
المسابقة غدا بمشيئة الحق تبارك وتعالى. 


نعود إلى الآباء والأبناءء وتعالوا سويا نكتشف بعض ملذات قواعد 
البيانات. 


كل جدول في قاعدة البيانات وحدة مستقلة بذاتها وفيها حقل مميز 
يسمى المفتاح الأساسي أو الرئيسي وقد فعلنا هذا في الجدولين الأباء 
والأبناء وخصصنا كلا من حقل رقم الأب وحقل رقم الإبن كحقلين 
لمفتاحين أساسيين. 

للمرة المليون: ما هو المفتح الأساسي؟ 


هو حقل يميز كل سجل في قاعدة البيانات ويمنع تكرار البيانات فيه 
لأكثر من سجل واحد ولا يسمح أن يكون فارغا. 


اذا حاو لت إضافة جل في جدو ل الأباء و الأبناء بدر ن إبخال قيمة 


TT أن‎ E 
البيانات في الدنيا. بعد عام 1970 طبعا.‎ 


ثم تحدثنا عن الحقل الغريب. ما هو الحقل الغريب؟ 
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هو حقل يتم إستعارته من جدول ما ويوضع في جدول آخر ولا یمکن 
أن يكون فارغا ويجب ان يكون مشابه لقيمة موجودة في الجدول الذي 
تم منه الإستعارة. سنشرح بتفصيل أكثر بعد قليل. 


د ا اها اعا وه لادا اخ الل افر 
من ول الان وو ق ف و 0 د ون اکن 9 ن ون 
لي ماذا يحدث لو عكسنا أي أخذنا رقم الإبن من جدول الأبناء 
ووضعناه (كسلفة) وكحقل غريب في جدول الآباء؟ من يجيب؟ ماهي 
المشكلة في أن نعكس؟ 


للإجابة نعود للمشكلة الأساسية --- ركز -- فكر معي -- هل يمكن أن 
يكون لإين أكثر من أب وأحد؟ الإجابة لا إذا أول إستنتاج هو أنه لإ 
يوجد لأي أبن أكثر من أب واحد» ويمكن أن يكون للأب أكثر من إبن 
اا کون ا 


الآن سأترك إجابة هذا السؤال لكم وأعود إليه مرة أخرى فيما بعد« 
السؤال مرة أخرى لماذا لا يكون الحقل الغريب هو مستعارا من 
جدول الأبناء ويوضع في جدول الآباء؟ أي عكس ما فعلنا حتى الآن. 


وصلنا أنه يوجد حقل غريب في جدوJ‏ اJأڊiاء‏ م4 FatherNum‏ 
تم إستعارته من جدول الآباء» وقلنا أن أحد شروط قواعد البيانات هو 
أن الحقل الغريب لا يمكن أن يكون فارغا ومع ذلك عندما قمنا 
باضافة السجل: 


0 خخالد 9 -- إترك الحقل الغريب فارغاً 
إلى جدول الأبناء لم يحدث أية مشاكل لماذا؟ لأن قاعدة البيانات حتى 


الآن لا تعرف أن هناك علاقة بين الجدولين» السؤال البديهي» كيف 
ننشىء هذه العلاقة. 
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قبل أن تستمر إحذف كافة السجلات من جدول الأبناء؟ إإأين 
الأذكياء؟ من يقول لماذا؟ 


قاعدة عامة: ركز -- إكتب - إحفظ -- تأكد دائما أن الجداول كلها 
فارغة بدون سجلات قبل أن تقوم بإنشاء العلاقات. 


لا تمسح بیانات جدول الآباء حتی وان کان هذا يعارض القاعدة 
الا ا 


لدينا الآن جدولين جدول الآباء وفيه خمس سجلات لأباء مختلفين»› 
وجدول الأبناء ولا يوجد فيه أية بيانات. 


أقفل الجدولين تم من قائمة( sامه٣‏ أدوات) أختر 
Relationships )‏ علاقات) 


سيظهر لك صفحة في الخلفية وقائمة فيها أسمي الجدولين: 
الول دول و ضط رفن2 

نشط الجدول الثاني واضغط زر إضافةلكA‏ 

إضغط زر اغلاق أو اقفالمءما© 


ماذا تری.. جدولين في صندوقين وكل صندوق يحتوي على الحقول 
الى قبت ان ها 

إِضغط على حقل ۳ں ٥۲‏ ۸ج۴ في جدول الآباء وإستمر بالضغط 
ثم إسحب حتی تصل إلى ٣ا ٣٥۲ N‏ اج۴ في جدول الابناء ثم إترك 
الا و 


أريدك عزيزي القارىء ن تستمر بالنظر ال هذه الصفحة لعدة دقائق 
وتقرأ كل كلمة فيها بهدوء وروية. 
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سأعود إليك بعد قليل. 
تحياتي»۰۰ 
مرحباء»» 


ماذا تسمي الأبن الذي فقد أباه ۔۔۔۔۔۔۔۔ صح --- یتیم!!! 


نعود إلى السيد ©5 K0‏ في أحد قوانينه الشهيرة» عند تصميمك لأي 
قاعدة انات تاكةد انه لا يوذ اام مهما كان التن ولا إتهار التكامل 
والتماسك 1أ 69| الخاص بقاعدة البيانات. 


سنعود لهذه النقطة بشرح مسهب. 


أمامك نافذة إسمها (تحرير العلاقات) وتكاد تكون أخطر وأهم نافذة 
على الإطلاق في برامج قواعد البيانات --- كل البرامج وليس 
الآكىس فقط 


ماذا نرى في هذه النافذة؟ 


قائمتين مظللتين لا تستطيع تغير هما واحدة فيها ء6۲طاج۴ أي جدول 
الآباء والاخری 90۸58 اي جدول الأبناء --- تحتهما مباشرة قائمة إذا 
ضغت عليها ترى سرد لكافة حقول كل جدول. 


في الدفتر الذي بين يديك اكتب الجملة الموجودة في مربع الإختيار 
الأول وهي غير منشطة وهي (فرض التكامل المرجعي) وتذكر أن 
كلمة تكامل هي تماساک وهي ما شرحناه سابفاراا gr‏ عiہ|‏ 


موافق. 
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اك غاا او 


افتح جدول الأبناء وادخل البيانات التالية: 


0خالد 12 --- إترك الحقل الغريب فارغا وانتقل لسجل جديد - 


- ماذا حدث؟ 

لم يحدٿث شيء --- !!!!!!!!!! لماذا؟؟ 

الآن أدخل السجل التالي: 

0 سعيد 10 -- وفي الحقل الغريب ادخل 1500 ثم انتقل 
للسجل الثالث 

ماذا حدث؟ ظهر خطا؟؟؟؟؟ لہا۱ ۱۱۱۱۱۱۱۱۱۱۱۱۱۱۱۱ااذا؟؟؟؟ 


بالإضافة ولكن هذا Ty TT‏ 
برامج قواعد البيانات بترك الحقل الغريب فارغا لإفتراض إمكانية 
عدم معرفتك بالقيمة المطلوب إدخالها --- ولكن لحظة من فضلك هذا 
خلل خطير فى تماسك وتكامل قاعدة البيانات» لماذا؟ لأن هذا الإبن لن 
يعرف أباه أبدا وبهذا ينشأ لديك سجل يتيم وهذا ممنوع. 


کي المحاولة الثانية حدث خطأ لماذا؟ لأننا أدخلنا قيمة 1500 کي 
الحقل الغريب وهذه القيمة غير موجودة لأي أب في جدول الآباء 
امو ق لرل الو فن ر عندما قلنا أن القيمة في 


الحقل الغريب يجب أن تكون قيمة موجودة في الجدول الذي تم 
الإستعارة منة؟!! 
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أرقام الآباء في جدول الآباء هي 3000 4000 5000 6000 
0 فقط إذا أدخلت ف جدول الأبناء أي قيمة غير القيم الخمس 
السابقة فلن تقبل القيمة --- جرب أية أرقام تريدها إستمر 
بالمحاولة.... لن تستطيع ولن يتم إدخال السجل إلا بقيمة من الخمس 
المذكورة» لماذا؟ لسبب بسيط جدا أنه هذه هي الطريقة التي يتعرف 
بها البرنامج على الاأباء فادا أردت معرفة أب الد تاخ الرقم من 
الحقل الغريب وتذهب إلى جدول الأباء وهناك تبحث بهذا الرقم عن 
صاحبه للحصول على الأب. 


والعكس صحيح اذا اردنا أن نعرف من هم ابناء اي اب نبحث عن 


تحیاتی»›»»› 
مرحباء»» 


صح --- ما قاله الأخوة صح -- لن يظهر الخطأء تعالوا نصحح 
ونرتب أفكارنا سويا... 


وتعالوا بنا أيضا نجيب على الأسئلة التي تركناها... 


قم عزريزي القارئ بحذف كافة السجلات الموجودة في جدول الأبناء 
قم بإختیار آدوات (sاھ‏ هآ( ومن (Relationships) ٽlقڻںږٺع pû‏ 
ثم إضغط على الخط الواصل بين الجدولين ثم اضغط زر ماما56 
على لوحة المفاتيح ثم وافق على الإلغاء. 


لقد قمت بحذف العلاقة بين الجدولين -- سنقوم بإنشائها مرة أخرى 
بعد قليل. 
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تركنا سؤالا في غاية الأهمية ... لماذا قمنا بإستعارة المفتاح الأساسي 
من جدول yT‏ الأبناء كحقل غريب؟ لماذا لم 
نفعل العكس؟ 


تعالو نفعل العكس ونرى ماذا يحدث للإجابة على هذا السؤال المهم 
والمهم جداء لا تنسوا أن للأب إبن أو اكثر أو لا أطفال» بينما للإبن 


قم بحذف الحقل الغریب ۸ ں ۸6۲۸ھ ۴ من جدول الأبناءء قم 
بإضافة حقل غريب في جدول الاباء وهر ں60۸ تأكد أن الحقل 
0NN UM‏ في کلا الجدولین هو نص ×۲6 بطول 3g‏ خانات. 


افتح جدول الآباء وتعال معي نضيف طفلين لهذا الأب: 

0 محمد مبارك الحربي 42 

لاحظ أن الحقل الغريب الآن هو رقم الإبن --- لنفترض أن معلومات 
الطفلين هي 

8سعید 7 

7 طارق 9 


بمعنى أنه سنضع في الحقل الغريب الرقم 888 لإضافة الطفل الأول 
إلى الأب أحمد ولا مشكلة في هذا-- قم بوضع 888 لإستكمال إدخال 


E 
مشاکل بالکیلو لا عد لھا ولا حساب:‎ 
وكل أسس قواعد البيانات العلاقيةء‎ C055 أولها نسف كل قو انين‎ 


انت الآن مضطر إلى تكرار بيانات وهذا ممنوع لأن أحد قوانين 
0هو عدم إدخال نفس البيانات أكثر من مرة واحدة» لیس هذا 
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۰ ا 


سے کا ا ل کے ل و وو رهاق 
راع ااا ی ر ع ن رک 7رر ن با 
إطلاقا وبهذا لن نستطيع أن نضيف أكثر من إبن واحد لكل أب وهذا 


قد يأتي من يقول غير حقل رقم الأب ولا تجعله مفتاحا رئيسا وهذا 


طبعا مصيبة لأنه يتنافى مع قواعد K0‏ التي تشترط وجود 
مفتاح أساسي في كل جدول. 


إترك السجل 9000 في جدول الآباء مع ابنه 888 وألغي ادخال 
7 بالضغط على ٥5ع‏ في لوحة المفاتيح. 


إستعارة الحقل من جدول الأبناء خطا... 
قم بحذف الحقل ل80۸ من جدول الآباء» قم بإضافة حقل 
غریب في جدول الابناء ں ۴۵۸6۲ وتاکد انه نص ٦٥×‏ بطول 


Oy 


اضغط آدوات ام٣‏ تم علاقات موہ ھا8 ثم أسحب 
الحقل F۴FatherN um‏ من جدول الاباء وألق4+ عٹ” FatherNum‏ 
في جدول الأبناء لنعود إلى نافذة تحرير العلاقات. 


واضح أن معظم من معي في هذه الدروس لديهم أكسس بالعربي 
(وهذا مصيبة اخرى) ولكني ساتجاوزها الان ونعود إليها فيما بعد 
111 
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تأكد أن الحقلين الموجودين هما ٣ں ۸٥۲‏ ج۴ من كلا الجدولينء 
إن لم يكونا فقم بإختيارهماء» تعالو نتأمل في هذه النافذة (تحرير 
العلاقات) 


يوجد أربعة أزار --- يهمنا الزر نوع الربط #مرآ امل إضغط 
a N‏ 


الإختيار الأول وليس لدي بالعربية لكني سأجتهد يعني أنه عند تشابه 
القيمة في ۳ں 6٥۲‏ ج۴ في الجدولين اظهر القيمة. بمعنى أظهر 
الآباء الذين لديهم أبناء فقط 


الإختيار الثاني: أظهر القيمة من الجدول الأول حتى وإن لم تكن 
موجودة في الجدول الثاني وأظهر أيضا ما تشابه... بمعنى أظهر 
الآباء الذين لدیهم أبناء وكذلك الآباء الذين لیس لدیهم أبناء 

الإختيار الثالث: أظهر الآباء الذين لديهم أبناء وكذلك الأبناء بدون آباء 


مستر 0000 عمل لنا زحمة --- صح؟ 


لا تفقد الهدف» الهدف هو ليس إنشاء قاعدة بيانات !!! الهدف هو 
كيف نصنع قاعدة بيانات متماسكة ومتكاملة. 


إختر الإختيار الأول وخزن وأخرج من نافذة العلاقات. 


في جدول الأبناء أضف السجلات التالية: 
0 خالد 7 3000 

10محمد 4 3000 

10سعید 9 4000 

0 طارق 12 4000 
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140أحمد 5 5000 

0سمیر 17 5000 

160فهد 1 5000 

70مشاري 3 9000 

0 الم 9 د إترك الل الغررب قارغا ت هذا كم اة قرا غد 
البيانات 

0 ناصر 11 -- إترك الحقل الغريب فارغا 


تعالو بنا نقفز عذة دروس إلى الأمام لتوضيح واحدة من أهم قوانين 
العلاقات في قواعد البيانات ونعود لمكاننا مرة أخرى 


اقفل الجدول وإنتقل إلى الإستعلاماتو عا Que‏ 

نشا إستعلام جديد بدون إستخدام المعالج --- كل المعالجات في 
الاكسس للمراهقين والمقلدين وليس للمحترفين!!! 

نشط كل جدول على حدة وإضغط إضافة ثم أغلق النافذة. 
لاحظ أن العلاقة ما زالت موجودة بين الجدولين 

انقر نقرا مزدوجا على الحقول التالية بالترتيب 

من جدول الاباءء F۴ athe‏ 


FatherNum 
FatherName 


من جدول الأبناءیہم؟ 
SonNum‏ 
SonName‏ 
FatherNum‏ 
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الآن ركز --- إنقر نقرا مزدوجا على الخط المرسوم بين الجدولين 
ستظر لك نافذة عنوانها (خصائص الرابط) 


هل ترى الإختيارات الثلاثة --- نعم هي نفسها التي رأيناها في نافذة 
العلاقات. 


الأن جاء دوري للإستمتاع بفنجان القهوة الذي بين يدي وجاء وقتك 


آنا سأستمتع بوقتي وبقهوتي وأنت ستقوم بتنفيذ الإستعلام ثلاث 
مرات» كل مرة تختار خاصية مختلفة من خصائص الرابط ومن تم 
تقول لي ما هي الفروق. 


أريدك أن تصرف عدة دقائق على هذا الإستعلام وترى الفروق بين 
الخصائص 


لنعود إلى0 ٠» 6K05‏ الإختيارات أو الخصائص الثلاث السابقة تسمي 
n‏ أەل 6۴۲م االربط الداخلي 
efi Outer Join‏ _الربط الخارجي من الیسار 
Ri hi Outer Join‏ الربط الخارجي من الیمین 


طبعا ليس لها علاقة أن يظهر الجدول سواء في اليمين أو الشمال 
أوکی؟؟؟ 


بعد أن تتأمل كثير وتفكر أكثر في الإختلافات بين الخصائص الثلاثة 
أريدك في الإستعلام أن تقوم بتنشيط الخط الواصل بين الجدولين في 


61 


الإستعلام ومن ثم تقوم بحذفه بالضغط على زر 6٥اه(‏ في لوحة 
المفاتيح --- نفذ الإستعلام وقل لي ماذا حدث !!! كيف حصلنا على 

0 سجل وااا۱۱۱۱۱۱۱۱۱١١١١ااو‏ --- سأفرح كثيرا إن أجاب أحد على هذا 
السؤال. 


ف ال ر رل القت ر بطر قنك کن ا فا نا 
نعود بعد قليل بمشيئة الحق تبارك وتعالى.. 


تحياتي»۰ 
مرحباء»» 


إذهب إلى صفحة العلاقات من خلال إختيار أدوات ءامها] تم 
عڻقlٽ Relationships‏ 


إحفظ التعديلات 


ثم إنشأ إستعلام جديد بدون إستخدام المعالج -- أضف جدولي الآباء 
والأبناءء ماذا تلاحظ؟ 


مع أننا قد قمنا بإلغاء العلاقة تماما ونهائيا ما زال آکسس یضع 
العلاقة؟ لماذا؟ من يجیب؟ 


لسبب بسيط جداء» لأننا جميعا نتبع القواعد الصحيحة والسليمة لبناء 
قواعد البيانات من خلال إتباع كل القوانين يساعدنا الآكسس وغيره 
من البرامج على إقتراح شكل العلاقات بين الجداول. حيث استنتج 
eT‏ الأبناء E‏ ا الأباء و 
أساسي (اي واحد) وفي الحقل الغريب ليس مفتاح أساسي (اي يمكن 
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التكرار) أي متعدد. 


أقفل الإستعلام بدون حفظ وعد مرة أخرى لصفحة العلاقات وتعال 
نتأامل في المزيد. 


اسحب مرة أآخری ۳ں ۸6۲ج۴ من جدول الآباء وأسقطه على 
NUM‏ ۴atherفي‏ جدول الاأبناء لفتح صفحة تحرير العلاقات. 


راقب مرة أخرى مربع (فرض التكامل المرجعي) وقطعا هي ترجمة 


بأطراف (طبعا ترجمة أسخف من السابقة) بل هي ترجمة سيئة للغاية 
وا اتر من الاد 

اسمحو لي أن اتجراً على شركة ميكروسوفت ونلغي سويا التعبير 
(راس باطراف) ونستبدله بجملة (واحد إلى متعدد) وهي اقرب من 
وجهة نظري إلى الترجمة الحقيقيةny One to Na‏ 


ماذا تعني هذه» أولا تعني أن شكل الرابط بين الجدولين هو (واحد من 
جدول) و (متعدد من جدول آخر) وهذا هو الوضع لدينا EEE‏ 


لکل أب واحد لدينا عدة أبناء متعددین 


وهذا هو أشهر نوع من انواع العلاقات والروابط بين الجداول 
وأكثرها إستخداما وأكثرها شيوعا: 


لكل عميل في البنك عدة حسابات 


لكل طالب في الفصل عدة مواد دراسية 
لكل حاسب آلي عدة خصائص مثل الذاكرة والقرص الصلب وغيره 
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لكل مصحف واحد عدهة سور 
لكل سور ة فى القر ان العظيم غذة انات 
وهكذا دواليك... 


عند إنشائك لعمارة او فيلا تبدأ بالهيكل الخرساني -- في قواعد 
البيانات هذا الهيكل هو الجداول في قاعدة البيانات ومجموع الجداول 
يسمى 5)٥|60١‏ او الهيكل لقاعدة البيانات» وحيث أن الهيكل 
الخرساني يتميز بالتماسك والتكامل مع بعضه البعض حيث تعمل 
الأعمدة والاأساسات والكمرات مع بعضها البعض لشد المبنى بشکل 
متماسكت كذلك تفعل العلاقات بين الجداول في تماسك وتكامل قاعدة 
البيانات 


اكثر العلاقات قوة وشدة وتكامل وتماسك هي (واحد إلى متعدد) 
جملة (واحد إلى متعدد) تفرض علينا إستنتاج إن هناك علاقات أخرى 
وهي: 

واحد إلى واحد 

متعدد إلى متعدد 

بالإستنتاج هناك ثلاث أنواع للعلاقات فقط بين الجداول كلها تساعد 
على تماسك وتكامل الجداول وبالتالي قاعدة البيانات --- مرة أخرى 
اقوى أنواع العلاقات بالترتيب هو: 

One 1o Nanyددعتn واحد إل‎ 

One To Oneدحاو واحد إلى‎ 

Many 1o Manyددعتم متعدد إلى‎ 


أما رأس بأطراف --- هههههههههههههه دعك منها 
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آمل أن نوع العلاقة واحد إلى متعدد مفهوم» سجل واحد في جدول ما 
مرتبط بعدة سجلات في جدول آخر» سجل واحد من جدول الآباء 
يمتل أب واحد مرتبط بعدة (متعدد) أبناء أو سجلات في جدول 
الأبناء. 

لاحظ في النافذة التي أمامك أن نوع العلاقة لا تستطيع تغيره حسب 
إختيارك» لأن نوع العلاقة هو استنتاج لعملية التصميم وليس إختيار: 
E NES NERS‏ 
إختيارا. 

و 

يعني أن تغيير تركيبة قواعد البيانات يغير نوع العلاقة (إستنتاجا) 
تعالوا نغير تركيبة قواعد البيانات: 


اغلق صفحة تحرير العلاقات وصفحة العلاقات 


افتح جدول الأبناء وقم بحذف كافة السجلات فيه لتلافي المشاكل في 


افتح جدول الأبناء (بعد حذف السجلات) وقم بتنشيط الحقل الغريب»› 
إجعل الحقل الغريب هو المفتاح الأساسي. 


احفظ التعديلات. 


افتح صفحة العلاقات من أدوات تم علاقات 
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انقر نقرا مزدوجا على خط العلاقة --- أين المجيبون --- ماذا حدث؟ 


هل تری نوع العلاقة؟؟؟ طبعا دعك من رأس برأس --- حسب إتفاقنا 
آاصبحت واحد إلی واحد 0"6 ۲١‏ 0"6 لماذا؟؟ 


NEUE E EEE هیا عاد‎ 


الربط الآن يتم بين حقلين كليهما مفتاح أساسي وأحد شروط المفتاح 
الأساسي هي عدم التكرار وعدم التكرار يعني (واحد) فقط»› 
وبالتالي في جدول الآباء لدينا أب واحد وفي جدول الأبناء لا نستطيع 
التكرار أي إبن واحد أي أن العلاقة أصبحت واحد لواحد أو واحد إلى 
واحد. 


سؤال متقدم للمحترفين والأذكياء --- متى نحتاج إلى علاقة على شكل 
واحد إلى واحد؟ ما أهميتها؟ ذكروني فيما بعد لأساعدكم على الإجابة. 


واحد إلى واحد هو ثاني أقوى أنواع العلاقات بين الجداول. 


CODD 


قم بتعديل تصميم الجدولين بحيث لا يوجد اي مفتاح رئيسي في 
فيهماء لا تحذف الحقول» فقط لا تجعلها مفاتيح رئيسية. 


أذهب إلى العلاقات وانقر بشكل مزدوج على الخط --- ما هو نوع 
العلاقة الآن؟ 


غير معرف أو عأج١‏ "6۲هل م| او بالترجمة الفعلية (غير 
محدد)... ضاع الآكسس ولا يعرف ماذا تريد وأصبحت قاعدة 
البيانات هشة وقابلة للكسر في أي لحظة. 


66 


العلاقة (متعدد إلى متعدد) في غاية الأهمية وللأسف (صعبة شوي) 
وحتى لا نمزق افكارنا سنؤخرها إلى ما بعد فهم العلاقة الأساسية 


الآن ولزيادة التعذيب آمل منك إعادة تصحيح الجدولين وكذلك إعادة 
إنشاء العلاقة بينهما على شكل واحد إلى متعدد واعادة إدخال العشر 
أطفال مرة أخرى. 


نستکمل مع العلاقات بعد قليل. 


تحیاتی»›»» 


مرحباء»» 
نستكمل ثم نعود للأخ (-) في تصحيحه لنا من عدم ظهور الخطاً!!! 


إلى أين وصانا الآن؟؟؟ ماذا أمامنا؟ كل العملية تدور حول تماسك 
وتکامل قاعدة البيانات› هذا التماسك يتم من انشاءِ جداول صحيحة 
حسب القوانین وکل جدول فيه مفتاح رئيسي» ويتم الربط (%90) 
بنوع واحد إلى متعدد ويوجد هناك ثلاثة خصائص لكل نوع (داخلي»› 
خارجي يمين» وخارجي يسار) 


nt ¥‏ اهي التكامل والتماسك 

rien F۴0‏ ۴هو الحقل الغريب ومن خصائصه: 

عدم إمكانية التكرار (الا إذا اردت الربط على شكل واحد إلى واحد) 
ألا يكون مفتاحا رئيسيا (الا إذا اردت الربط على شكل واحد إلى 
واحد) 

ألا يكون فارغا حتى لا يصبح السجل يتيما 

أن تكون القيمة المدخلة فيه مشابهة لأحد الأقيام الموجودة في الجدول 
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الآخر لا يصبح السجل يتيما. 


نستمر وما زلنا نحاول ونجاهد أن نصمم قواعد بيانات (متكاملة) و 
(متماسكة) 


لدينا في جدول الآباء 6 آباء حاليا أرقامهم 3000 4000 5000 
6000 7000 9000 

ولدينا في جدول الأبناء 10 أطفال أرقامهم 110 120 130 140 
150 160 170 180 190 


atherN Um‏ ۴هو رقم الأب وهو المفتاح الأساسي في جدول 


0NN‏ خو رقم الإبن وهو المفتاح الأساسي في جدول الأبناء. 


يوجد فرض للتكامل المرجعي. 


الآن إفتح أستعلام جديد وأضف الحقول التالية: 
FatherNum‏ 

FatherName 

SonNum 

SonName 

FatherNum 


نفذ الإستغلام واكثب ما يلي في الدقتر عندك: 
يوجد 6 آباء و 10 أطفال 


أنشأً جدولا بالمسطرة والقلم وقم بنقل سجلات جدول الآباء حتى 


تستطيع أن تراها 
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أنشاً جدولا بالمسطرة والقلم وقم بنقل سجلات جدول الأبناء حتى 


تستطيع أن تراها 


عندما ترى في الإستعلام خط بين جدولين فهو يعني الخاصية الأولى 
(اي نوع داخلي) وكما قلنا فالنوع الداخلي يظهر فقط السجلات من 
الجدولين التي تتشابه فيها الحقول المروبطة وعليه حصلنا على 4 
آباء ڍ فقط ولم نحصل لا على الأب رقم 6000 ولا على الأب رقم 
0 لمادا؟ 


لان هڏذين الأبوين ليس لهم أي أطفال وهذا منطقي ولكنه 
جدا من ناأحية التماسك !!! لماذا؟؟؟ 


لأن الإستعلام الذي بين يدينا لا يعطينا كم أب لدينا؟ نحن لدينا 6 آباء 
والإستعلام يقول 4 وهذا فيه مخاطرة. خذ هذا المثالء لدينا 50 طالبا 
في الفصل كل منهم قام بتسجيل 3 مواد ما عدا 4 طلاب» عدم 
تسجيل الطلاب لأية مواد ممنوع» كيف نعرف انه يوجد طلاب بدون 
مواد؟ 


مرة ة أخرى استصدار السجلات التي تتطابق فيها الحقول المربوطة قد 
يؤدي إلى مشاكل كثيرة في تحليل البيانات وتحويلها إلى معلومات 
للتخطيط و إتخاذ القرارات. 


قر خا ع ت ون اا 
لاحظ أن السهم يتجه إلى جدول الآباء. 


ركز معي: السهم يعني فقط السجلات التي تتشابه فيها الحقول 
المربوطة. عدم وجود السهم يعني كل السجلات. في هذه الحالة 
طرف الخط عند جدول الأبناء لا يوجد فيه سهم وهذا يعني (كل 
السجلات) أي كل الأبناء» وطرف الخط عند جدول الآباء فيه سهم 
ويعني فقط الأباء الذين رقمهم مشابه لرقم في الجدول الآخر. 


69 


E OOOO a ES 
190 ناء مء ولكن بالمقال حصان على طظلين أخرين 180 و‎ 


وهذا أخطر ما يمكن أن يحدث فى قواعد البيانات E‏ 
سجلات في جدول (المتعدد) بدون سجلات في جدول (الواحد) وهذا 
يؤدي إلى سجلات (يتيمة) وينسف تماسك وتكامل قاعدة البيانات من 
جذورها. 


عندما تحصل على سجلات في جدول المتعدد لا ترتبط بسجلات في 
جدول الواحد فلديك مصيبة في قاعدة البيانات وهي من اكثر الأخطاء 
شيوعا ومن أصعب المشاكل حلا. 


الآن غير إلى النوع او الخاصية الثانية وبهذا يتجه السهم إلى جدول 
الأبناء. نفذ الإستعلام سرى كل الأباء من جدول الأباء وسترى أيضا 
معظم التطبيقات تستخدم هذا النوع. 


كما تلاحظ فإن اليتمين لم يظهرا هنا رقم 180 و 190 وهما المشكلة 
الأساسية الآن في تماسك القاعدة. 


نعود لصديقنا (-( الذي جزاه الله خيرا نبهنا إلى عدم ظهور خطأ عند 
اختراق أحد قوانين C000‏ وإضافة رقم غير موجود في جدول 
الراك ال الكل :ار 


تعالوا نعيد هذه التجربة تم نقول للأخ (-) لماذا لم يظهر الخطأ (وهو 
طبعا ليس بسبب التكامل المرجعي) ... نوعا ما... سنشرح بعد قليل. 
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لدينا 6 آباء بأرقام 3000 4000 5000 6000 7000 9000 


افتح جدول الأبناء وإذهب إلى الإبن رقم 180 الذي ليس له أب 
وأدخل أي قيمة في الحقل الغريب. سيقبل منك دون أي خطأ لماذا؟ 


نعود لمستر ٥0000‏ 
ماهي خصائص الحقل الغريب: 


الآ يكون فارغا والا نتج سجل يتيم 

أن يكون مشابها لقيمة في الحقل المربوط فيه أي أحد الأقيام التالية 
)3000 4000 5000 6000 7000 9000( اي قيمة أخرى 
غير هذه القيم الست تؤدي إلى سجل يتيم لان الربط يتم بتشابه القيمة 
بين الحقلين المربوطين. 


الإجابة وببساطة هي: لصيانة قواعد البيانات. 


هذا التساهل في برامج قواعد البيانات والسماح باختراق أحد قوانين 
الوقت للتطرق اليه مستقبلا لأهميته. 


هل لازلت متخيلا معي أن قاعدة البيانات فيها آلاف الجداول وكل 


ماذا لو كنت تقوم بصilة Administrating & Maintaining‏ 
هذه القاعدة؟ 

ماذا لو كنت نتقل ملايين السجلات من قاعدة البيانات إلى نسخة 
إحتياطيةء إذا منعك الآكسس لخلل في تماسك القاعدة فلن تحصل على 
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قبل النسخ. 

ماذا لو تسرع مدخل البيانات وأدخل بیانات الأبناء وأنت ما زلت 
تصمم القاعدة ليوفر الوقت» إذا منعه الأكسس فلن يستطيع إستكمال 
سجلات جدول الأبناء قبل أن يقوم بإدخال بيانات الأباء. 


نعم هو تساهل ولكن له خدمات كثيرة» هذا التساهل أخف بكثير في 
البرامج الأخرى مثل أوراكل وغيرها. 


إذا لا علاقة بالموضوع حتى الآن (بفرض التكامل المرجعي) هذا 
قواعد البيانات. 


وهذه مشكلة لا نواجهها نحن حالياء لأن قاعدة البيانات التي نقوم 
بتصميمها جديدة ومن الصفر ولا يوجد لدينا بيانات ولا صيانة ولا 
شيء. 


مرة أخرى سمح لك الآكسس بإدخال قيم (غير شرعية) تساهلا بأحد 
القوانين لتبسيط عمليات النسخ والصيانة والتجربة والخطأ. 


ونستغل الوضع هنا من تنبيه الأخ (-) لنقول حذار من البدء في 
إدخال البيانات لقاعدة بيانات لم تتكامل ولم تتماسك بعد... تذكرون 
عندما طلبت حذف كافة سجلات جدول الأبناء لاإجراء بعض 


التجارب» لماذا؟ حتى لا نقع فيما نبهنا إليه الأخ -. 


بعد تقديم الشكر للأخ الصاحي معنا (بل الصاحى جدا)» نعود ١‏ 
ا a‏ ڪي وو 
الأيتام في سجل الأبناء. 


الآكسس لم يساعدنا في منع وجود أيتام في قاعدة البيانات» والقانون 
ينص على أن وجود ايتام سيؤدي إلى مشاكل بالكيلو. 


72 


تعال وشاهد معي مدی هشاشة قاعدة البيانات التي نقوم بتصميمها 
افتح جدول الأباء وقم بحذف الأب صاحب الرقم 3000 ثم احفظ 
اذهب واعبث قليلا في الإستعلام الأخير الذي قمنا بإنشائه. 


اختر النوع الثالث من خصائص العلاقة لرؤية الأيتام؟؟ ماذا ترى؟ 
أصبح لدينا أيتام بالهبل بعد ذبح أبيهم!!! 


ن اا ا 0 
4500 تم عد تنفید االإستعلام» ماذا حدث؟؟؟ 


فاده انات مه غر ماك على ادق 

اعد إدراج بيانات الأب رقم 3000 مرة أخرى في جدول الآباء 
وصحح بيانات 4500 إلى 4000 مرة آأخرى. 

وأسمحوا لي بفنجان من القهوة. 


تحیاتی»›»› 


مرحباء»» 


مازلت في مرحلة إنشاء أسئلة المسابقة -- وآمل أن أستطيع إنهائها 
الليلة بمشيئة الله. 


نعود إلى العم 0000 والعلاقات» ونكرر أن ما نقوله هنا ليس له 
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علاقة بأي برنامج بل ينطبق عل Microsoft SQL sı Oracle‏ 
وغیرهم ايضا. 


ماران هفنا هى اتماسكة و تكامل فا عد البانات كذلك ميل عة 
إدخال البيانات لصديقنا المسكين (مدخل البيانات) 


ووصانا أن قاعدة البيانات لدينا ما زالت هشة وقابلة للكسر لسبب أن 
طريقة تصميمها تتيح للحقل الغريب أن يحتوى بيانات غير موجودة 


لنزيد من حجم المشكلة قليلا للتفاعل مع صديقنا (-)» إذهب إلى 
صفحة العلاقات من أدوات ثم علاقات. 


إختيار (فرض التكامل المرجعي) سيظهر لك مربعان إضافيان 
اتركهما الان بدون علامة صح. إضغط موافق» ماذا حدث؟؟؟؟ 


كنا e‏ اتام في قاع البيانات !!! ولهذا ll‏ 
اکن و ونا کر ان اط ا من و 
أْماذ|؟؟؟ 


صح -- لأن قاعدة البيانات أصلا فيها أيتام. 


ما هي المشاكل التي نحاول حلها والتي واجهتنا في الحلقة السابقة: 
نستطيع ترك الحقل الغريب فارغا 

نستطيع ادخال اي قيمة في الحقل الغريب دون شرط وجودها في 
الحقل المرتبط فيه 

نستطيع حذف أب وترك آبنائه بدون أب --- أیتامOrphans‏ 
نستطيع تعديل رقم الأب في جدول الآباء من 4000 إلى 4500 
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وبهذا يفقد الأب أولاده المرتبطين فيه على رقم 4000 وليس 4500 


كل ما سبق مشاكل تؤدي إلى عدم تكامل وتماسك قاعدة البيانات -- لا 
بد من حل المشاكل الأربعة السابقة واحدة تلو الأخرى. 


ا 


اذهب إلى جدول الأبناء وقم بوضع أب للطفلين 180 و 190 وليكن 
ابوهما رقم 6000 
أي ادخل 6000 في الحقل الغريب. 


لنتأكد من السجلات. 


في جدول الاآباء 
0محمد سعید أحمد42 
0خالد عبد الله الصيعري 61 
0سعيد محمد المالكي 32 
0ئطلال عبد العزيز المسبحي29 
0سمير خالد الجار الله46 
0احمد مبارك الحربي42 


في جدول الأبناء 

10 خالد 3000 7 
10 1محمد3000 4 
0 سعيد4000 9 
0 طارق4000 12 
140أحمد5000 5 
0 سمیر 5000 1⁄7 
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0 1فهد5000 1 
70مشاري9000 3 
180 صال6000 9 
0 ناصر6000 11 


اذهب مرة أخرى الى العلاقات وضع صح على مربع فرض التكامل 
واترك المربعين الأاخرين فارغين. 


افتح جدول الأبناء وأضف الطفل التالي: 
0-سلطان 12 


وحاول أن تضع أي قيمة غير القيم التالية (3000» 4000» 5000» 
600؛ ۰7000 9000) وکذلك لا تترکه فارغا. 


ماهي المشكلة التي تم حلها من الأربعة مشاكل نفعاليه؟ 


تم حل المشكلة الثانية حسب الترتيب السابق» الآن إما أن تضع قيمة 
موجودة في جدول الآباء آو ن تترکه فارغا... لن يستطیع مدخل 
البيانات الآن إختراع قيمة من عنده. 


إذهب إلى جدول الآباء -- حاول حذف أي أب له أبناء مثل الأب رقم 
0 مممممم لا تستطيع مهما حاولت لأن ذبح الأب سيترك ... 
ماذا؟ نعم أيتام ولهذا فهو ممنوع. 

حاول تعديل رقم أي أب له أبناء مثل الأب رقم 4000 حاول أن 
تجعله 4500 !إإمممممممم لا تستطيع مهما حاولت لان تغيير رقم 
الاب سيترك كل الأطفال الذين أبوهم رقمه 4000 بدون آأب. 
جدول الأبناء فارغاء ومن التجربة العملية في السوق أقترح ترك هذه 
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التغرة دائما في بداية التصميم مع أخذ ملاحظات عن هذه الحقول 
ومن تم حلها فيما بعد. لماذا؟ 


نعود لصديقنا (-) وتوجيهه لناء السبب هو أننا في مرحلة التفكير 
والتكامل لقاعدة البيانات ولا نريد كل دقيقة أن ينط لنا الآأكسس او إاس 


كيو إل ويظهر لنا خطأ ما 


أما كيف نحل المشكلة الرابعة فهي من خصائص الحقول» إفتح جدول 
الأبناء ذ في التصميم ونشط الحقل الغريب وأنظر في الأسفل سترى 
خاصیة (مطلوب) أو ٣٥۹۵‏ اuںههR‏ عند تعديلها من (لا) إلى (نعم) لا 
نستطيع ترك الحقل الغريب فارغا. 


لدينا الآن قاعدة بيlنlاتٽت Intergaled‏ أي متكاملة ومتماسكة --- 
ولكن لحظة .... توقف... 


يو جد مصيبة في هذا الٿتصمng!‏ !!!| IIIIIIIIIII!!|!!!1!‏ 


يو جد الآن مشاكل حقيقية في تصميم قاعدة البيانات حتى مع تماسكها 
وتكاملها. 


من يقول لي لمادا؟ 
فکرووووووووووووووووووووووووووا 


ولا تنسوا و القراءة لا تفيد ---- إكتبوا كل الملاحظات. 
تحياتي»۰۰ 
مرحباء»» 


أولاً... للأخ (---) الله ما أجمل وأروع إجابتك وبالذات الإجابة على 
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سؤال متى نستخدم العلاقة واحد إلى واحد. 


بالهنرهط -- في حالة واحدة فقط -- عندما نحتاج إلى زيادة النواحي 
الأمنية في قاعدة البيانات (طبعا ليس حماية قواعد البيانات بل حماية 
البيانات نفسها من الإطلاع عليها) ويتم هذا بفص حقول الجدول 
الواحد إلى جدولين أو أكثر ويربط بينهما بنفس المفتاح الرئيسي -- 
العلاقة واحد إلى واحد تعني أن الربط يتم بين مفتاحين رئيسيين. اما 
كيف نفصل بين الجدولين وكيف نوزع الحقول فهذا جزئية قد نتحدث 
عنھا إذا أسعفli‏ لوقت yتسnأٴ Normalization‏ 


لدينا الآن قاعدة بيانات تنطبق فيها كل قوانين C050‏ ومتكاملة 
زمتماسكة. ولكن فيها مشكلتين أساسيتين تظرق بعض الأخوة لهم 


المشكلة الأولى: ماذا نفعل إذا أردنا فعلا أن نحذف أي أب؟ 
المشكلة الثانية: ماذا نفعل إذا أردنا فعلا أن نغير رقم أي أب؟ 


في التصميم الحالي لا نستطيع؟؟؟ 


لحظة.... ركز معي 

إذا كان الأب بدون أطفالء فلا مشكلة لدينا -- نستطيع حذفة وهذا لا 
ينتج عنه أيتام» وكذلك نستطيع أن نغير رقمه وأيضا لا ينتج عن هذا 
أيتام. بالإستنتاج نستطيع أن نحذف أب بعد أن نقوم أولا بحذف كل 

أولاده. ولكن هذا فيه اجهاد كبير لماذا؟ 


لأننا نتخيل أن قاعدة البيانات فيها 5000 جدول وكل جدول فيه آلاف 
الحقول وكل جدول فيه ملايين السجلات» هل من المنطقي والعملي 
أن نذهب كل مرة إلى جدول (المتعدد) ونحذف السجلات كلها تم 
نذهب إلى جدول الواحد وحذف سجل واحد من هناك» طبعا العملية 
مجهدة وقابلة للأخطاء... لا بد من وجود حل عملي ومنطقي. 
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ANE E A E E Î 
(حذف) والمشكلة الثانية (تحديث) او (تعديل)‎ 


افتح صفحة العلاقات من أدوات ثم علاقات من القائمة. 
نقر مزدوج على الخط الواصل بين الجدولين. 


ا 


واحدة فيها كلمة (تحديث مأجلملل )و الأخرى فيها (حذف ) 
اوهو ما نبحث عنه فعلیاًء صح؟ 


إقرأً مرة أخرى بتمعن وتركيز أكبر» ستجد ان الحذف يتعلق 
بالسجلات ....مممم 

وات حل لرل ع 

كالعادة»› لماااا ۱1111 00000۱01۱۱ادا؟ 

ماذا يعني کل ما سبق»›» عن مادا نبحث؟ ماذا نفعل؟ 


رید حلا للمشكلتين أعلاه... 


نريد عن تعديل أو تحديث رقم الأب في جدول الآباء ----- ماذا؟ أين 
يتم تلقائيا تحديث رقم هذا الأب في جدول الأبناء. 


ضع علامة صح على الإختيار الأول (تحديث الحقول المرتبطة) --- 
اقفل النافذة 
إذهب إلى جدول الآباء وغير (عدل) (حدث) رقم الأب 4000 إلى 
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4500 


ماذا حدث؟؟ 


EEE‏ ---- لم يظهر خا 


أقفل جدول الأباء وإفتح جدول الأبناء --- الآن يجب أن تجيب ماذا 
حدث؟ ماذا تغیر؟ 


آلیا قام الآکسس أو 6ا٥ھ0۲۵‏ أو SQ)‏ ۸8 بتحدیث -- بتغيير -- 
O RT ET‏ 

(المرتبط) ولا يوجد الآن أب برقم 4000 كل أب يحمل الرقم القديم 
أصبح الان يحمل الرقم 4500 


هل تلاحظ التماسك والتكامل --- لا يمكن صناعة أيتام -- أقفل 
الجدول 


بالإستنتاج وبالقياسن نذهب إلى العلاقات مرة أخرئ من أذرات ت 
علاقات 


الآن ضع علامة صح على الخاصية الثانية (حذف السجلات) -- 
أعتقد أنها واضحة الآن 

إضغط موافق وأقفل صفحة العلاقات تم إفتح جدول الآباء. 

قم بحذف الأب صاحب الرقم 4500 -- ماذا تقول الرسالة؟ لاحظ في 
السابق كان الحذف ممنوعاً ولكنه الآن يقول لك في الرسالة (لا بأس) 
سأحذف لك هذا الأب ولكن بشرط واحد هو أنني سأحذف كل أولاده 
أولاً -- هل توافق؟ إضغط نعم. 


تم حذف الأب --- ليس هذا فقط --- اقفل جدول الآباء وأفتح جدول 
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الأبناءء ماذا تلاحظ؟ 

نعم لا وجود لأي إبن بأب ذو رقم 4500 

قاعدة بيانات متكاملة ومتماسكة من الدرجة الأولى. 

الرجاء ممن لم يشتغلوا معي خطوة بخطوة عدم الاستمرار حيث 
تفهم أقرأ وطبق يدويا من الاول. 


تعالوا بنا الآن نزيد قليلا من التعقيد ولا تنسوا أن الهدف خلال رحلتنا 
كاملا هى النخافطة عل اتاك والكامل. 


تحیاتی»»»› 
مرحباء»» 


في حوالي %90 من الحالات العلاقة بين الجداول هي واحد إلى 
متعدد وفي حوالي 1 هي واحد إلى واحد. 


e e 


ولكن عالم قواعد البيانات ليس سهلاً دائما وممتعاء تعال نحاول حل 
هذه المشكلةء في ترقيم السيارات عندنا في المملكة العربية السعودية 
مثلاً لوحات السيارات تأخذ 6 خانات ثلاثة أحرف وثلاثة أرقاي 
عندنا نريد إنشاء قاعدة بيانات لكافة سيارات المملكة لدينا مشكلة 
أساسية 


تعالوا بنا سويا نحاول حل هذه المشكلة. 
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الحل الأول هو إنشاء مفتاح رئيسي يتكون من 6 خانات وهذا قد 
يكون حلا سريعا للمشكلة ولكنه يتطلب حلولا برمجية للمساعدة متلا 
لعمل وأممج" أو ترسيم بين الحروف العربية والحروف اللاتينية 
منلا. 

لنسهل الموضوع ونفترض أن الإدارة العامة للمرور منعتنا من 
إستخدام حقل واحد. 

ما هو الحل... إنشاء حقلين كل واحد منهما 3 خانات» وبهذا يصبح 
لدينا حقل من تلاثة أرقام وحقل آخر من ثلاثة حروف. ولتسهيل 
العملية سأفترض أن الحروف باللغة الإنجليزية متلا للهروب من 
اا فال ال رس الف ر ف ارات لن لفن 
أن نفهم سويا الموضوع) 


وبهذا لترقيم سيارة ما 376 ۸1-۲ بحيث نضع K1‏ في حقل 
ونضع الرقم 376 في حقل آخر 


هذا حل جيد (حتى وإن كنت لا أحبذه إطلاقا من الخبرة) ولكن الهدف 
هو شرح الموضوع. 


الأن ما هو المفتاح الرئيسي لهذا الجدول. 

إنشأً جدولا في قاعدة البيانات ۷ا" ه۴ وفيه الحقلان التاليان: 

أا ateا۴نص‏ 3 -- للكناية عن الأحرف الثلاثة لرقم لوحة السيارة 
UM‏ ateNا۴نص‏ 3 -- للكناية عن الأرقام الثلاثة لرقم لوحة 
السيارة 


لا تنس قاعدة مستر K050‏ والتي تنص على أن لكل جدول مفتاح 
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أساسي» لاحظ كلمة (مفتاح) وليس (مفاتيح !!!! )واضح؟ 


مرة أخرى للتأكد من طرح الموضوع بشكل جيد --- مفتاح واحد فقط 
وليس مجموعة من المفاتيح. 


نعود إلى لوحة السيارة --- ما هو المفتاح الرئيسي في هذا الجدول 
علما بأنه يوجد لدينا الآن أربع سيارات لوحاتها كالتالي: 


رقم لوحة السيارة الأولى376 11 --- 
رقم لوحة السيارة الثانية950 11 ) --- 
رقم لوحة السيارة الثالثة376 85 --- 
رقم لوحة السيارة الرابعة 950 8×0 --- 


لنفترض أن الحقل 6 _|هج|۴ الخاص بالحروف هو المفتاح 
A‏ 

صح» لن نستطیع تكرار البيانات في هذا الحقل وبالتالي لن نستطيع 
إدخال آ1 وكذلك 810 أكثر من مرة واحدة --- مشكلة --- هذا 
الل لا یلح آن تگون مفتاحا ريسا 


لنفترض أن الحقل ٠ں ۴|٥‏ الخاص بالأرقام هو المفتاح 
الرك 2ا ا 

صح» لن نستطيع تكرار البيانات في هذا الحقل وبالتالي لن نستطيع 
إدخال 376 وكذلك 950 أكثر من مرة واحدة ---- مشكلة --- هذا 
الحقل لا يصلح أن يكون مفتاحا رئيسيا. 


لدينا حقلين فقط وكلاهما لايصلح أن يكون مفتاحا أساسيا وفي نفس 


الوقت لا بد من وجود مفتاح أساسي؟؟؟ معضلة !! وطبعا لم تسمح لنا 
ادارة المرور باضافة حقل جديد ندعیه اساسیا. 
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ما هو الحل؟ 


يقول لنا C050‏ إذا كنت مضطرا لجعل المفتاح الرئيسي يتكون من 
کی من سل ا و کن ن ان الل فط ها كن 
مضطرا. . . 


واضح أن كلمة (مضطرا) هذه تعني إستثناء وليس قاعدة وهي تعني 
ا ا تخا ل امن ف الل :ایا ع ولك هن نا 
SCG SS‏ 


قم بتنشیط الحقلین 16٥ھ‏ ا۴ و Num‏ مatاP۴P‏ مع بعضهھما البعض 
من خلال الضغط والسحب من أقصى اليسار أو أقصى اليمين حسب 
الآكسس لديك ومن ثم إضغط المفتاح في شريط الأدوات. 


الآن ركز بشدة معي--- لا يوجد أكثر من مفتاح أساسي في الجدول - 
- متففین؟ 
إذا ماذا نسمي الذي أمامنا؟ 


الذي أماماك الآن هو مفتاح أساسي واحد فقط ولکن يتكکون من حقلين 
إثنين!!! 
ماذا يعني هذا؟ 


کک كل حقل على حدة!!!! 
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وطالما أنه يمنع تكرار البيانات في المفتاح الأساسي -- فالتكرار هنا 
ممنوع لمجموع الحقلين وليس لكل حقل على حدة!!! 


تعالوا بنا نفهم بشكل أفضل 


خزن الجدول بإسم sئهأه|۴‏ بعد أن تطمئن انه يوجد رسمة مفتاح 
بجانب كل حقل من الحقلين. 


تعالوا بنا ندخل بيانات في هذا الجدول... 


أدخل الحروف ۲ K1‏ في حقل ع ها۴ تم حاول الإنتقال إلى 
السجل التالي--- ماذا حدث؟ ظا طبعاء»» لماذا؟ لأن حفل المفتاح 
الأساسي لا يمكن أن يكون فارغا -- ولكننا وضعنا قيمة في هذا 
الحقل --- صح وضعنا قيمة في حقل اهاج |۴ ولكنه ليس هو 
ڪه الأساسي -- مره خر ماهو ع الاي في هذا الجدول 
البعض ولیس ع1 ع۾|۴ لوحدها وكذلك س PlateNum‏ 
لوحدها. 


امسح القیمة ۸۲ وحاول إدخال 950 في حقل ہں N.‏ ماaا٥۴‏ لن 
إذا كان المفتاح الأساسي يتكون من حاصل جمع أكثر من حقل فإن 
ترك أي حقل منهم فارغا يؤدي إلى أن المفتاح الأساسي فارغا وهذا 
ممنوع. 

لن تسد تستطيع الإنتقال من هذا ا١‏ لسجل إلا في حالة واحدة فقط وهي 


إدخال K1‏ في اع اعاه|۴ وكذلك إدخال 950 في P|lateNum‏ 
وهذا منطقي حسب ما فهمناه. 
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قم بإدخال السجل السابق وتعال ندخل سويا سجلا آخر وهو 1) 
6 حظ أن الآأكسس وكذلك الأوراكل وغيرهما سيسمحون لك 
بإادخال هذه اللوحة ... من يجيب لماذا؟ 


لماذا سمح لنا الأکسس بتكرار K1‏ في حقل† م ]ماما۴ ؟ من 


٠: لحلل‎ 
N 


الإجابة لأن 6 ۴|٥]‏ ليس مفتاحا رئيسيا 
الإجابة لان ۳ں ماھ|۴ لیس مفتاحا رئیسیا 


تحياتي»۰۰ 
مرحباء»» 


بالنسبة للأخوة والأخوات الذين يسألون عن بريدي الإلكتروني فهو 
Info@arabserver.net‏ 

بالنسبة للاخ الذي وضع القوانين الخاصة بالسيد 0(0 K0‏ فاتقدم له 
بجزيل الشكر راجيا من الجميع: 


عدم ترجمتها إلى اللغة العربية ونشرها -- حتى لا تؤدي إلى بلبلة 


ملاحظة أن القوانين من القانون التاسع إلى القانون الثاني عشر لم 
تطبق حتى الآن في أي لغة قواعد بيانات لا الآأكسس ولا الأوراكل 
ولا 1S SQ]‏ ولا غيرهاء وبالتالي لم يتم إنشاء أي قاعدة بيانات 
علاقية في العالم تتبنى القوانين من 9 إلى 12. 
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أما إقتراح الأخ بتجميع كل المشاركة في ملف وورد فآمل منه 
أن يقوم بهذه نيابة عني شاكرا ومقدرا له هذا الجهد. 


نعود... 


كم آنا سعيد أن وأنا أقرأً الإجابات على السؤال الذي تركناه في الحلقة 
السابقة وقد كانت كل الإجابات صحيحة وتشرح الصدر. فعلا أصبح 
المفتح الأساسي هو ناتج مجموع قيمتي الحقلين وبهذا لن تستطيع 
تكرار رقم اللوحة الذي يتكرر في كلا الحقلين. 


أي جزل واوا الكاضن ا فم ارجات الا راتو ی م 
بهذا القدر. 


قم بإنشاء الجدول التالي سواء في الآأكسس أو الأوراكل أو MS‏ 
ا S۵وهو‏ جدول الأصناف إطلق عليه الإسم "s‏ ]| وضع فيه 
الحقول التالية. 


NUM‏ temMانص‏ 2 -- مفتاح اساسي 
temNameانص‏ 
Co‏ temارقم‏ 


إحفظ الجدول بإسمء ]| 


أضف السجلات التالية في جدول الأصناف: وم )| 
0محاية2 
91مسطر ة4 
2قلم رصاص 1 
93منفلة2 
94قلم حبر15 
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5سبورة45 
6لة حاسبة20 
7براية1 
98شنطة70 
9دفترق 


النظر عن المنطق) أي آمل ألا يقول أحد أن طفلا عمره سنة واحدة 
قد إشترى منقلة!!! 


آین نحن؟؟ 


ن الأصناف السابقة لأطفاله ثم نر يد إنشاء إستعلام يقول لنا إجمالي 
ما دفعه كل أب مقابل الأصناف التي قام بشرائها لأطفاله. 


بعد حفظ الجدول 65]| وإدخال البيانات السابقةء إفتح صفحة 
العلاقات» ثم إضغط بالزر اليمين للماوس في إي مكان فارغ وقم 
بإختيار (إظهار جدول) وأضف جدول وء" ]| إلى صفحة العلاقات. 


في 18S SQ)‏ إذهب إلى و۲4۳ وها وإضغط بالزر الأيمين في 
مكان فارغ وإختر ٥اطج‏ ۲ ۸١‏ ثم أضف و" ]| إلى صفحة 
العلاقات. 


أريد من يقرأ معي أن يحضر فنجانا من القهوة أو الشاي» ويسن قلما 
من الرصاص ويفتح صفحة بيضاء جديدة في الدفتر ويعصر فكره 
ین الأصناف وص مt|‏ 
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¢(¢666(6¢6¢66666666666CCCG ا١١! تعذبواا‎ 


تحیاتی»›»› 


مرحباء»» 


وصانا (بعد التفجير الذي عطانا والعياذ بالله) لئ کیف نربط Items‏ 
الجدول الجديد الخاص بالأصناف... 


نعود إلى مستر ك00 K0‏ للمساعدة... 
لنركز... 


جدول اا ا هذه العلاقة العلاقة يجب أن تنشاً 
بین جدولي "6| و.80۸58 


إذا استعرنا ہں ]| من جدول |6۳١5‏ ووضعناہ حقلا غرییا 
في جدول الأبناء فإننا ننشىء علاقة واحد إلى متعدد (كل طفل لديه 
مجموعة من الأصناف) ولكننا نكون خلقنا مشكلة تكرار الأبناء لأن 
الطفل رقم 120 يحق له شراء أكثر من صنف وبالتالي إذا قام بشراء 
براية ومحاية قمنا بنتكرا رقم الطفل 120 وهذا مستحيل لأن رقم 
الطفل مفتاح أساسي. طبق على الورق لتفهم. 


إذا إستعارة ل ]| ووضعه في جدول الأبناء حل مرفوض. 
إذا استعرنا ہں S0۸‏ من جدول ئ80۸ ووضعناه حقلا غریبا في 


جدول الأصناف فإننا ننشىء علاقة واحد إلى متعدد (كل صنف يملكه 
مجموعة من الأطفال) ولكننا نكون خلقنا مشكلة تكرار الأصناف لأن 
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الصنف رقم 91 يمكن شراؤه من أكثر من طفل وبالتالي إذا قام 
طفلان بشراء الصنف رقم 1 المسطرة قمنا بتكرار رقم الصنف 91 
مرحباً بك في عالم الضياع 


باءت كل محاولاتنا لإنشاء علاقة (واحد إلى متعدد) بين الأصناف 
والأبناء--- باءت إلى الفشل. 


ما هي المشكلة التي أمامنا؟؟؟ 
المشكلة تكمن في التالي: 


وفي نفس الوقت كل صنف يستطيع أن يمتلكه أكثر من طفل 


أي ان العلاقة من "٣s‏ ]| إلى 56/۸5 هي واحد إلى متعدد 
وفي نفس الوقت العلاقة من 50١s‏ إلى |]6"s‏ هي واحد إلى متعدد 


إذا كانت العلاقة (واحد إلى متعدد) في الإتجاهين فإن العلاقة تصبح 
(متعدد إl‏ nتعددNany Many 1o‏ ( 


مرحبا بك إلى هذا النوع من العلاقات.... 
في علاقة (متعدد إلى متعدد) ربط الجدولين ببعضهما البعض ---- 
ركز --- دقق - افتح عينيك س 


مهما حاولت أن تربط بين جدولين بعلاقة (متعدد إلى متعدد) فلن 
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تستطيع والسبب نك ستضطر ال الغاء المفتاح الأساسي في أحد 
الجدولين للسماح بالتكرار (للمتعدد) وهذا ينسف تماسك وتكامل قاعدة 
البيانات. 


إا ما هو الل 


ألوووو -- مين معي على الخط --- مستر ل000 مرحبا --- ما هو 
الحل... 


الحل : إنشاء جدول تقاطعي -- ٥اطھ‏ ۲ ٥۸‏ اام ںل شکرا مستر 
Codd‏ 


أهلا.... ما هو الجدول التقاطعي؟ --- إستخدم الدفتر 


أولاً ما معني --- ٥0‏ لل في سكك الحديد هناك دائما محطات»› 
هذه المحطات س e‏ بتغيير | ك الحديد للإتجاه الى 


جاءت فكرة التقاطع لهذا العالم الفذ. 

عندما تصطدم بجدولين العلاقة بينهما في أي إتجاه هي علاقة (واحد 
إلى متعدد) تكون أماماك علاقة (متعدد إلى متعدد) وللربط بينهما تقوم 
بإنشاء جدول جديد يسمى بجدول التقاطع أو ٥اab‏ 7 Juncti0n‏ 


رل الا هن ال لرل ا ا اها ا 
الأساسي من الجدولين: 


الجدول و ]| مفتاحه الأساسي 0ں "N‏ ]| نقوم بإستعارته 
الجدول $0۸5 مفتاحه الأساسي N0‏ 80۸ نقوم بإستعارته 


أنشأً جدولا جديدا فيه الحقلين التاليين: 
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2صناtemNum‎ 

iSonNumنص4‏ 
ماذا ینقصنا الآن؟؟؟؟ من یجیب؟؟؟ صح؟؟؟ --- لا يوجد جدول بدون 
مفتاح أساسي!!! 


آها... 
مغهمممممممهمم 


إذا جعلنا ]| هو المفتاح الأساسي فلن نستطيع أن نبيع 
مسطرة لاکٽر من طفل 

وإذا جعلنا ں٣60‏ هو المفتاح الأساسي فلن يشتري أي طفل 
اي الل 


نعم مجموع الحقلين هو المفتاح الأساسي... 


نشط کلا الحقلین ہں عا و SNN um‏ واضغط علی المفتاح 
الأساسي 


"بهمس وبصوت خفيف --- هناك مشكلة --- بعدين.. 
الأن أحفظ الجدول بإسم ك "ائم وتعالو بنا نربط هذا الجدول 
في صفحة الحلاقات بإستخدام الزر اليمين أضف الجدول 


te58ا0ns‏ إلى صفحة العلاقات 
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کر 


من جدول الأبناء إسحب n٥ںN 80٩‏ وأسقطهھ علی ٥ں N‏ 80۸ في 


جدول 5 80۸٤|٥٣‏ تم ضع صح علی التکامل وصحین علی کل 
من التعديل والحذف. لاحظ شكل العلاقة في أسفل الصفحة ---- نعم 


هي واحد إلى متعدد. 


من جدول الأصناف إسحب mہں nN‏ م†| وأسقطھ علی Item Nun‏ 


في جدول ٣۳٥اsئ٣ 8٥‏ ثم ضع صح على التكامل وصحین على 
كل من التعديل والحذف. لاحظ شكل العلاقة في أسفل الصفحة ---- 


نعم هي واحد إلى متعدد. 


واجب منزلي.... 


هل نستطيع تكرار رقم الإبن في" ایم ؟ لماذا؟ 
هل نستطیيع تكرار رقم الصنف في" ایم ؟ لماذا؟ 


من يقول لي ما هي المشكلة الآن؟ 
اين العباقرة الذين سيحلون هذه المشكلة؟ 


فکروووووووووووووووووو وتعدبوووووووووووووو 
ملاحظة للاخ ------- :لم أفهم عزيزي ماذا قصدت بهذه الجملة 


(ولماذا نضع جدولين العلاقه بينهما هي 0۸6 0 0۸6 والسبب هي 
كمسالة أمنيه لحفظ البيانات الذي اعرفه ان العلاقه هي التي تفرض 
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نفسھا فلایمکن ان نجعلھا ٥٣٥ ٥ ٥۸٥‏ الا اذا كانت کكذلك) 


قاعدة البيانات وقد شرحنا في أحد الدروس اننا نستطيع تغيير هذه 
العلاقة ما عدا (متعدد إلى متعدد) عندما نشاء متى ما نشاء كيفما 
نشاء. أوضح لي قصدك . 


مرحباء»» 


اشكر الاج ) ------- ( ل قام بتصحييح عدد a‏ ت نعم خطا 
مطبعي» آما إستحداث حقل اسمهھ ۸ں ٥ ٣N‏ ]ا0 فطبعا خطا لان 


طبعا مشكلتنا الان هي ما طرحه الأخوة جميعا وهي عدم القدرة على 
شراء صنف رقم 91 وهو المسطرة من نفس الطفل صاحب الرقم 
0 متلا. وهذا هو أجمل ما في العلاقة (متعدد إلى متعدد) والتي 
تتيح إنشاء جدول على شكل جسر أو تقاطع من خلال جدول جديد 
اسمه جدول التقاطع اط۵ ۲ ٥۸‏ امال » بعبارة أخرى لدينا جدول 
جديد نستطيع أن نفعل فيه ما نشاء. 


مرة أخرى (من قال أن جدول التقاطع يقتصر على الحقلين الغريبين 
فقط) ؟؟9؟!!!! 


قذرن: عند تفه القع والخضانض كحورل العا برمتها إلى (مخرد 
عد) فقط. 


أي أن الطفل هو نفسه والمسطرة هي نفسها --- لم تتغير الخصائص 


وبهذا يكون أفضل الحلول هو القيام بعد الأصناف --- بإختصار الحل 
هو الكمية. 
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أضف الحقل التالي إلى جدول التقاطع:s"عاء S0‏ 
¥ رقم 
إحفظ الجدول 


ما الذي حدث الآن... عند شراء أي طفل لأي صنف نضع كمية 
الشراء 


قم بإضافة السجلات التالية إلى جدول التقاطع: ٨s‏ ء†اsئرمS‏ 
3 90 110 

11091 2 

110 92 7 

110 955 

110 999 

120 93 6 

120 99 2 

130 90 2 

130 94 2 

130 97 4 

170 92 12 

حيث يمثل العمود الأخير الكمية المشتراة من كل صنفرQ‏ . إحفظ 
الجدول. 


أين نحن الآن؟ وماذا إستفدنا حتى تاريخه؟ 
كل الموضوع يتعلق بتماسك وتكامل قواعد البيانات 
النماذج والتقارير والمايكرو في الأكسس هي للعبث وإضاعة الوقت 


حتى لغة البرمجة المرتبطة فيها والتي تسمى ۷/8۸ أر sومعA‏ 
6ع هي مجرد عبٿث وهي لغة مشوه جدا من لغة البرمجة۷6 
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أن برامج قواعد البيانات المتقدمة (المعتمدة على خادم S۷6"‏ ) 
مثل ٥ا02‏ و SQL‏ 5 لیس فیها لا نماذج ولا تقاریر ولا 


. الهيكل ا او الخرسان لقاعدة البيانات بشکل 


أن عملية ربط الجداول (ليست نزهة) تتم في دقائق. والغريب أن 
معظم من قابلتهم في حياتي المهنية يصرفون %10 من وقتهم على 
بناء الجداول والإستعلامات و%90 لألوان النماذج والتقارير 
وتحريكها وترقيصها وتدليعها وتسطير ها --- غريب!! 


لقواعد بيانات من الوزن الثقيل والتي يمكن أن تباع في السوق يجب 
للباقي من الزبرقة والبهارات والنماذج وغيره. 


أن العلاقة بين الجداول دائما غير واضحة في البداية ويمكن تشكيلها 
بعدة طرق وعدة حلول» ومن هنا جاءت فكرة (فريق العمل) عندما 
تقوم بتصميم قاعدة بيانات فإنك تعقد سلسلة من الإجتماعات ينصب 
معظمها على الجداول والربط والإستعلامات وتظل تدور في هذه 
الطكة تى تشمن تماسك ر نامل اا عة 


إستعلامات بالدرجة الأولي» والإستعلامات معقدة جدا إذا كان تصميم 
الجداول بطريقه سهلة وواضحة. 


إرجع الت ملاحظتي للاخ ( د في بداية هذا الرس > ببساطة 
قلت له خطا (وريحت دماغي واعصابي) أماذا؟ لا ارید ان افكر في 
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SS‏ ا ا أسهل ووأوضح وأفضل 


ماذا لو طلب صاحب قاعدة البيانات (التي نقوم بتصميمها له) أن 
يكون هناك حقل يوضح تاريخ الشراء للأطفال ؟؟؟؟!!!! 

في الحل السهل الذي قمت بإتباعة لم ألتفت إلى حل ( ت 
متلافيا صداعا وفكرا إضافياء لكن بإدخال (تاريخ لشراء) فإن هذا 
يعني أن الطفل سيشتري 10 مساطر يوم السبت و5 مساطر يوم 
الخد التكزار الان لا مفر هتة او شنكون مشكلة خانقة نطب 
دعوة فریق العمل لإجتماع. لأنه في حالة ادخال تاریخ خ الشراء إنهار 
التماسك والتكامل وعندها نذهب الى الأخ ( ------) ونبوس راسه 
ونقول له (تكفى إشرح) مرة ثانية. عند إدراج تاريخ الشراء لا يوجد 
حل سهل سحري وسريع» ليس لدي حل جاهز... انا وانتم بحاجة إلى 
التفكير العميق الذي قد يؤدي الى إعادة تصميم القاعدة بشکل مختلف. 
طبعا دائما وآبدا هناك حلول لأي مشكلة في قواعد البيانات. 


ما الذي آقوله؟ 


إن تصميم الجداول وربطها عملية في غاية التعقيد وقد عملت أكثر 
من تجربة في المحاضرات التي ألقيتها لأرى أن كل مجموعة تقوم 
بتصميم قاعدة البيانات بطريفقة مختلفة وكلها صحيحة ولكن الفروق 
تكمن في سهولة حل عن آخر»ء وكلمة سهولة تعني سهولة في إدخال 
البيانات سهولة فى إعادة فك وتركيب قاعدة البيانات سهولة في 
صيانة قاعدة البيانات وسجلاتها وحقولها. 


العملية ليست نزهة ... العملية ليست طبق من السلطة يحضر في 
دقائق مکونا من شوية حقول على کام إستعلام على شوية بهارات 
ماكروز على نموذج من هنا وتقرير من هناك. 


أخي ( SEES‏ ) سنعود إليك لتنقذنا فيما بعد عندما نفجر رؤسنا تفكيرا 
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في كيف نربط جداول قاعدة بيانات المستوصف. 


كان الهدف هو الحصول على المبلغ الذي دفعه كل أب مقابل 
مشتريات إبنه ولأن جدول الأصناف فيه ئم٥٤‏ "| كان 

بالضرورة وجود حقل يوضح الكمية ل لضرب الكميتين 
والخصزل على فة الثر اء 


صحيح أننا قمنا بعمل بعض الإستعلامات دون شرحها وهذا ما 
سنفعله الآن. 


ماذا سنفعل؟ 

سنترك الجداول والروابط ونعود إليها فيما بعد... متى؟ بعد أن 
نتحدث على واحدة من أقدم لغات البرمجة في العالم... وهي لغة 
SQL.‏ 


تحیاتی»»»› 


مرحباء»» 


ى فل لدابت 


5Q‏ تعني Structured Query Langu a9٥‏ وهي لغة 
برمجة قواعد البيانات ولا علاقة لها ببرنامج شركة ميكروسوف 
ier ost SQL Server‏ هي مجرد لقافة من شركة 
ميكروسوفت لإستعارة الإسم. 


اذا: 


)4هي لغة برمجة 
SQL Server‏ 5هو خادم متقدم لقواعد البیانات صمم من 
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شركة إسمها ميكروسوفت و 1S‏ إختصار llكnlمMicrosof†.a‏ 


ومن هي عمتهاء حيث يعج الإنترنت بهذه المعلومات ويمكنكم البحث 
عنها بسهولة وقراءتها ونا أنصح بذلك متى تشاءون. 


التركيز على الحرف 4 حيث أنه هو المفتاح السحري للعملية كلها. 


Q = Query 


6¥ تعني إستعلام إستفسار إستفهام إستنباط إستنبطاااح ---- 
وصلت الفكرة؟؟؟ 


المرال الى رالتقلدى هرما ارق ين الول والا عا 


الجدول هيكل خرساني شديد التماسك والتكامل يعمل مع بقية الجداول 
مع محافظته على استقلاله وشخصيته. الجدول هو رجل ببدلة رسمية 
منتصب الطول عابس الوجه لا يمزح ويسير في الشارع بجدية 
مفرطة وإلتزام كبير. 


لا تمزح مع الجدول... الجدول لا يقبل المزاح ول لا العبث ويغلب 
عليه التماسك والشدة والعبوس والتجهم. 


الإستعلام (ولد صايع) على رأي الأخوة في مصر ... حبوب» لذيذء 
يحب المزاح» سهل التعامل معه»ء يقبل كل أنواع المزاح والعبث ولكن 
إذا مزحت معه من (اليمين)» إذا مزحت معه من (اليسار) --- نسف 
قاعدة البيانات من جذورها. هل سمعت بمثل إتق شر الحليم اذا 
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غضب --- هذا هو الإستعلاما!! 


لأن السيد 0000 مزق حقولنا ووزعها في جداول مختلفة كان لا بد 
من طريقة ما لتجميع هذه الحقول مع بعضها البعض!!! 


جدا جدا في كيفية تشكيل الإستعلام. 


4هي لغة تستخدم علم (المصفوفات) من الرياضيات للوصول 
إلى الحلول --- ولا يهمك حقيقة ماذا تستخدم ولكن للعلم بالشىء فقط 
لمحبي هذا العلم الرائع المسمى المصفوفات كعء ا۲ج ومفردها 


مصفو ف Matrix.‏ 


الغريب في 5641 أنها عميقة الجذور وفي غاية التعقيد الشديد جداء 
ولكن الممتع في الموضوع أن كامل اللغة بكل أبعادها تتكون من أقل 
من 10 أوامر -- صدق أولا تصدق أو حتى أقل من 5 أوامر على ما 
أذكر !!! 


قلنا أن 5Q1‏ تمزح من الجهة اليمين --- وتغضب من الجهة اليسارء 
ما معنی هذا؟ 


هناك إستخدامين إثنين فقط للغة ا50 واحد أسميه مزاح من اليمير 
ك إستخدامين إثنين و يه مزاح من اليمد 
والاخر مزاح من اليسار: 


الإستخدام الأول (مزاح من اليمين): هو الحصول على البيانات بأي 
شكل وبأي كيفية 

الإستخدام الثني (مزاح من اليسار) : هو تحدیث Skeleton‏ او 
الل ارفا ا ا ي ر ا ا ول 
والروابط ---- اااووو خطير جدا!!! 
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الأكسس (بغبائه) وليتبع قوانين شركة ميكروسوفت في وجود برامج 
سهلة تشعر مستخدميها بسهولة قواعد البيانات وضعت لك برامج 
حفر ةداخل الا كس تساغدك غل ناء الارز ل ررضت 
صفحة تساعد کا إنشاء العلاقات»› ووضعت صفحة سهلة تساعدك 
على إنشاء الإستعلامات وهكذا.... 


هذه البرامج الصغيره (في الحقيقة) مجرد واجهة بينك وبين 5Q1‏ › 
الذي يقوم بالعمل كله من ألفه إلى يائه هر اه8 


أشهر أوامر S۵1‏ هو الإمر (إختر) أو إنتقي 7٥ع S٤1‏ 
يحتاج شرح هذا الأمر عدة أيام وعدة محاضرات ولكنني سأضعك 


على الطريق الصحيح للتعلم ثم تنطلق أنت. 


تركيب جملة 5٤1-01‏ يتكون من عشرات الأوامر الفرعية 
وآسهل شکل لها هو: 


Selecta 

بعدها فراغ أو مسافة 

بعدها إسماء الحقول مع وجود فاصلة بعد كل إسم حقل 
بعدها فراغ 

بعدھا کلمةہ م٣۴‏ 

بعدها إسم الجدول 


إفتح إستعلام جديد في قاعدة بيانات راا ج۴ 
ستظهر لك نافذة تسألك عن الجداول التي تريد أن تستخدمها في 
الإستعلام 


إضغط إغلاق ©1٠50‏ بدون إختيار أي جدول... 
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من القائمة الرئيسية إختر (عرض ۷1W‏ )ثم (عرض --- SQ)‏ ) 
ماذا تری؟ 

ترى جملة واحدة فقط وهي 1 )ع S8٤1‏ 

إكتب الجملة التالية في السطر الأول 

Select FatherName From Fathers 


نفذ الإستعلام --- ماذا حدث؟؟ 


ليس هذا فقط» بل من قائمة (عرض ۷1٥۴۷‏ )إختر (عرض 
التصمیم ۷٥W‏ 9۸ یم( )۰۰۰ مممممممم... 


ماذا تری؟؟؟ 
مرحبا بك في عالم الم‌امS‏ 


تحیاتی»›»»› 


مرحباء»» 


قلنا أن الأكسس ومتله 1S SQ)‏ يساعدنك على إنشاء الجداول 
والإستعلامات من خلال برامج صغيرة --- نعم ركز --- فقط 
يساعدنك ولكن إنتبه مجرد مساعدة وليس حل كامل متكامل!!! 
ماذا يعني هذا؟ 


يعني أنك لن تستطيع الفرار من ا5۵ ولن تستطيع الهروب من 
تعلمها إلا إذا أردت أن تصمم قاعدة بيانات مبسطة لإستخدامك 
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۱ شش ي. 


إذا أرت أن تبيع قواعد بيانات 

ذا أردت أن تكون ضمن فريق عمل لتصميم قواعد البيانات 
إذا اردت أن تقبض نقود وتبيع للسوق 

إذا أردت أن تكون محترفا 


يجب أن تتعلم أوامر 5۵1 وإلا فإنك تضيع وقتك ولن تقفز حاجز 
المعلومات التي لديك»» بعبارة أخرى ستبقى معلومات تراوح مكانها 
وستصب جام غضبك على النماذج والتقارير والمايكرو التي تستنزف 
جهدا لا نتيجة ولا قيمة له. 


الجملة: 
Select FatherName From Fathers‏ 


تخضع للتركيب ×هأ" 6S۷‏ الذي شرحناه. 


Selecta 

ثم فراخ 

ثم فراخ 

ثم کلہم٣۴‏ 

ثم فراغ 

ثم إسم الجدول 

ماذا إذا كنت أريد أكثر من حقل - بسيطة بين الحقول ضع فاصلة 
مثل 

Select FatherName, FatherNum From Fathers 


مستر ٥0000‏ يصر على تمييز الحقول ويقول لنا حتى لا تتورطوا 
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فيما بعد في مشاكل كبيرة وكثيرة (قوموا بتمييز الحقول عن بعضها 
ان ا ا 


إفترض أن لديك جدولين مختلفين وفي كل جدول منهما يوجد حقل 
إسمه Father] N2۳68‏ هذا يخلق واحدة من أخطر مشاكل قواعد 
البيانات والذي يسمى ۷†أاوأط "۸ ويعني الإلتباس والغموض. 
حيث لن تفهم 541 من أي جدول تريد بيانات الحقل 
FatherName‏ 


وبالطبع يستحيل أن يكون هناك جدولان بنفس الإسم في نفس قاعدة 
البيانات --- لنصحح ونتبع شروط مستر ل0٥‏ 


Select Fathers.FatherName From Fathers 
Select Fathers.FatherName, Fathers.FatherNum 
From Fathers 


وضعنا إسم الجدول قبل كل حقل وبينهما نقطة. 

إعكس الموضوع في الآكسس أو ۱8S SQ)‏ قم بإنشاء إستعلام 

بالطريقة التقليديةء افتح إستعلام جديد» نقر مزودج على جدول 
۴6 إغلاق تم نقر مزدوج على كل من الحقلين 
FathersNumeoiFatherName‏ 

قم بإستعراض جملة )8۵ من قائمة عرض ۷ء۷ 

سترى نفس الجملة السابقة --- طبعا دعك من الفاصلة المنقوطة في 
نهاية الجملة --- لا قيمة لها الآن 


ماذا يعني هذا کله؟ 
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يعني أننا نستطيع إستغلال طريقة الآكسس وكذلك 18S S|‏ في 
إجراء الكثير من التجارب ومن تم الإطلاع على جملة ا8 وكيفية 
ترکیبها 


نترك قواعد البيانات كلها 


Operations‏ اArithmetica‏ أو العمليات الحسابية وهي عمليات 
الضرب والقسمة والجمع والطرح والأسس والوغاريتمات والجذور 
والمثلثات والفراغية والجبر و..ز إلخ 


Comparison Operators‏ أو عمليات المقارنة مثل المساواة 
وعدم المساواة وأكبر من واصغر من و...إلخ 


" أو العمليات المنطقية وهي" و" "أو" "لا‎ gi caا‎ Operations 
ğlJAND, OR, NOT ... 


نعود إلى قواعد البيانات وهي تستخدم كل ما سبق من العمليات. 


طبق المثال التالي.. 

من خلال إستعلام ا کل الأباء من جدول الأباء وکل الأبناء من 
جدول الأبناء -- قمنا بهذا سابقا ولكن الآن أريد أن تشاهد جملة 
Select‏ 


SELECT Fathers.FatherNum, 
Fathers.FatherName, Sons.SonNum, 
Sons.SonName FROM Fathers INNER JOIN 
Sons ON Fathers.FatherNum = 
Sons.FatherNum 
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کل ما أریدہ منك ھو الترکیز على الجملة ٣(‏ امل )|٣ ٣6۲‏ من یتذکر 
--- من يكتب معناء طبق النوعين الآخرين وشاهد تركيبة الجملة 
Left JoindlSsRight Join‏ 

تدريس 5۵41 والتي تحتاج إلى الكثير من الوقت والتمارين 

والتجارب والشرح المباشر. 


جملة 8۲ 0۸9٤۴‏ هي الجملة التي تساعد على ترتيب نتائج 
الإستعلام 


إفتح نافذة استعلام جدبد في وضع SQL‏ واکتب الجملة التالية 


Select FatherNum From Fathers Order By 
FatherNum 


ماذا تعني؟؟ 
أظهر كافة بيانات الحقل ۳"6 4ل١6۲‏ ج۴ من ترتيب أو فهرسة أو 
(عرض التصميم) وشاهد كيف تم إنشاء الإستعلام بالطريقة التقليدية. 


كيف نستعرض السابق تنازليا 


Select FatherNum From Fathers Order By 
FatherNum DESC 


أنظر إلى الكلمة في النهاية 065٥‏ وهي إختصار ل 
14 nم‌c es‏ اي تنازلي -- طبق وجرب وشاهد وأکتب 
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ملاحظاتك. 


ماذا لو أردنا كافة الآباء الذين رقمهم أكبر من 5000؟ 
نستخدم خاصية الشرط ۷1٤۸۴٤‏ أي عندما !!! ترجمھا كيف تشاء 
إ! 


Select FatherNum From Fathers WHERE 
FatherNum>50O000 


لاحظ إستخدم أحد (عمليات المقارنة) -- نفذ --- طبق --- شاهد--- 
فکر E‏ أكتب کے أخص والا لن تفهم شیئا.. . 


طبعا ستجد خطأ في الجملة السابقة ... لماذا؟ لأن رقم الأب (نص ( 
sText‏ 5000 رقم» خم الدوال -- وهي جزء من قواعد البيانات 
في الآكىس أسمها ۷۸1 أي ماج۷ أو قيمة» في MS S1‏ 
نستخدم وج أي التحويل. 


Select FatherNum From Fathers WHERE 
VAL(FatherNum)>5000 


ماذا لو أردنا أن نغير عنوان الحقل N2۳6٥‏ ام ط†۴a‏ لأنه باللغة 
الإنجليزية ونحن نريده بالعربية 


SS TIT a 


Select 
FatherName 
As 


]اسم الأب[ 
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From 
Fathers 
ASC 


٥!إختصار ۸5٥٥۸۵۸9‏ أي ترتيب أسماء الآباء من الألف 
إلى الياء. 
أريدك عزيزي القارىء أن تصرف وقتا لا يقل عن أسبوعين (فيما 


كل ما فعلنا حتى الآن هو المزاح الذي يتقبله 541 منا دون المساس 
فكامل و ادك قاغةة انات 


لنوع الثاني من المزاح ينقسم إلى شقين: 


الأول: تعديل في البيانات داخل الجداول (في السجلات) -- وينبغي 
الحذر 

الثاني: تعديل في الجداول والحقول والروابط بينها --- وهو الخطير - 
- وينبغي الحذر الشديد جدا 


تعدل بيانات الجداول يتم من خلال: 
اأضافة سجلات جديدة 

تعديل سجلات موجودة 

حذف سجلات موجودة 


تعالوا نستمتع بلغة 8@1 ونضيف سجلين جديدين لجدول الآباء 
نستخدم الأمر |٠56۲‏ أي أدخل ولا تنسى عزيزي القارئ نحن 
نتحدث عن ©5 وهي نفسها بالضبط (تفريبا) في كافة برامج قواعد 
البيانات مٿل الاکىس و Oracle MS SQL‏ ڃ Sysbase‏ 
وغیرها. 
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يا جماعة -- يا أصحاب الموقع --- لدي مشكلة في التحول بين 
العربي والإنجليزي -- عموما أنا غشيم في طرق المنتديات سأحاول 


Insert Into Fathers Values 


) 
1500 


39 
( 


نفذ الإسنعلام وتأكد من جدول الآباء أن الأب 1500 قد تم إضافته 


ومعناها أدخل السجل التالي بالقيم الموجودة بين القوسين حسب 
ترتيب الحقول في الجدول... 


بالضغط على (عرض التصميم) لن تستطيع»»»› لن يساعد الاكسس -- 


عات الان م اا 


تعالوا نعدل عمر الأب 1500 من 39 سنة إلى 36 سنة بإستخدام 
لغة S1‏ 

Update Fathers SET FatherAge = 36 WHERE 
VAL(FatherNum)=1 500 


نفذ الإستعلام وقم بالتأكد من أنه تم تعديل عمر الأب 1500 من 
جدول الآباء 
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1500 تعال بنا نحذف الأب‎ 
Delete From Fathers WHERE 
VAL(FatherNum)=1 500 


نفذ وتاکد... 


واجب منزلي... 


بإاستخدام لغة 81 


أظهر بيانات الأباء الذين أرقامهم أقل أو تساوي 4000 

أظهر بيانات الأصناف التي تكلفتها تقل عى 5 ريالات 

إسأل نفسك خمسة أسئلة أخرى على الأقل ثم حلها بإستخدام لغة 
SQL‏ 


تحیاتی»»»› 


مرحباء»» 


في لغة: 84 
عند الإضافة نستخدم 0| Insert‏ 


عند التعديل نستخدم ]5 Update...‏ 
عند الحذف نستخدمع ]ما0 


ركز معي مرة أخرى وتذكر دائما وأبدا أن هذه أوامر ا8 ولا يهم 
ال 541 من آين تستخدمهاء مين يتذكر الطبقة الاأولى؟ 


في الطبقة الأولى (الخاصة بالنماذج التقارير) لا يهم من أين أتى أمر 
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اQسواء‏ من: 


VB 
VB.Net 
C#.Net 

++ÛC .net 


Java 
Access 
Excel 


MySQL 
Interdev 

Asp 
Asp.Net 


Oracle Designer 

إلخ... 

كل ما سبق يمكن أن يستخدم في إنشاء الطبقة الأولى وكل البرامج 
اعلاهہ تستطيع التخاطب مع قاعدة البيانات (الموجودة في الطبقة 


الثالثة) 1 ا SQL‏ وهذا ممتاز ورائع لأننا ل يهمنا الأداة 


كل البرامج والتطبيقات تستخدم نفس أوامر لغقاSQ‏ 


ا ف SQL‏ كل قاع الداتات ريحتا هذا إلى التدريت 
ال ل اض ال م ا 
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لإنشاء جدول جديد في قاعدة البيانات نستخدم الأمر عأCrea‏ 
Table‏ 
في إستعلام جديد أفتح (عرض-801) وادخل السطر التالي. 


4 
اأتس طط 
. 0 " 


في آکسس 

Create Table Tests (TestlD text(4), TestName 
text(25), TestAge Number) 

والله مشكلة الأقواس --- تعبت انا من لخبطة العربي والانجليزي --- 
صلحو ها انتم!!! 


Query Analyzerمlختulڊ,‎ MS SQL في‎ 

Create Table Tests (TestlD char(4), TestName 
char(25), TestAge int) 

ضخخوا الاقر اسن 


أذهب إلى الجداول وتمتع بالجدول الجديد !!! في MNS SQ)‏ لا بد 
من عمل R۲٤۸‏ للجداول حتى ترى الجدول الجديد. 


ستلاحظ أنك لا تستطيع تنفيذ هذا الأمر أكثر من مرة --- من يجيب؟ 
11 


لتعدیل جدول نستخدمعاطھ ۲ Alter‏ 
احذف جدول نستخدمااھ ۲ مہDr‏ 


صدق أو لا تصدق عزيزي القارىء أن هذه الأوامر: 
Select‏ 
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Update 
Insert 
Delete 


Create Table 
Alter Table 
Drop Table 


هي فقط (تقريبا) كل أوامر لغة!!!! 8Q1‏ 

ا کا کے الا کل ار فاا ار ا ا اد 
إلى الكثير من الصبر والجهد والتمارين والشرح وهاهنا أحاول أن 
اضف على الطرتق الصخت» ذا أردت الإخراق فى فراع 
البيانات لا بد من إتقان الأوامر السابقة. لاتيأس»» خذ كل واحد من 
الأوامر بروية وبهدوء وقم بعمل المئات من التجارب والمحاولات 
وما إلى ذلك... لاحظ في قائمة إستعلام Q6٣‏ في الآكسس سترى 
الكثير من أنواع الإستعلامات مثل: 


استعلام تحدیث 
استعلام انشاء جدول 


ال 


كل هذ الإ ادمات من انشا ها من لذن لامر الباة 
وإستيضاح الفروق بينها في غاية الأهمية. 


لعل الوقت يسعفنا فيما بعد ونلقي مزيدا من الضوء على لغة اه8 
لنعود إلى قاعدة البيانات وجدولي الآباء والأبناء 
من ينشاً لي أستعلام سواء بلغة ا5۵ أو من خلال (عرض 


التصميم) يوضح إجمالي ما دفعه كل أب مقابل مشتريات إبنه؟؟ 
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قاعدة أخرى من قواعد السيد 0۵00© وتنص على أنه يمنع وضع أي 


مرة أخرى --- لا يمكن متلا في الجداول أن تضع تاريخ ميلاد الإبن 
ثم تضيف حقلا للعمر تقوم من خلال البرمجة بطرح تاريخ الولادة 
من التاريخ الحالي وثم التحويل للحصول على عمر الطفل. 


عندما يقول 0000 ممنوع فهو يقصد أنك تستطيع عمل هذا ولكنك 
لن تحصل على قاعدة بيانات متكاملة ومتماسكة. 


كافة العمليات الحسابية تتم في الإستعلامات... 


E‏ السابق الذي وقفنا عنده نرید إجمالي المدفوع من كل 
أب مقابل مشتریات إبنه 


تعالو نری کیف يتم هذا... 


إستعلام جديد أضف الجداول كلها ثم إنقر نقرا مزدوجا على الحقول 
التالية بالترتيب: 
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من جدول الاباء: 
FatherNum‏ 
FatherName‏ 


من حذول الاأبتاء 
SonNum‏ 
SonName‏ 


نفذ هذا أستعلام --- ما هي النتيجة؟ من يقول لي ماذا تعني هذه 
النتيجة؟؟؟ 


أرجع إلى التصميم بعد التفكير في السؤال السابق ومحاولة الحل 
وتعال نحسب تكلفة الشراء. 


لحساب كل ركز (كل) عملية شراء نضرب أءه ٥‏ ]| في الكمية 
المشتر اة Qty‏ 


في (عرض التصميم) للإستعلامات ستلاحظ أن السطر الأول هو 


۴|0 أي الحقل ونحن ليس لدينا حقل نحن لدينا عملية حسابية 


في عمود فارع اكتب: 
Qty*ItemsCost‏ 


لاحظ كيف يعدل الأكسس... 
الأسئلة إلا الذين لديهم كل ما عملناه على ورق!!! 


من قائمة (عرض ۷1W‏ )إختر مجاميع اهاه (ملاحظة 


(الاجماليات)) 
ماذا تلاحظ ؟ نعم أتت خدمة جديدة (سطر جديد) عنوانه (إجمالي) 
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وتحت كل حقل ظهرت جملة (تجميع حسب --- Group By‏ ) 
والمجاميع هي خاصية من اوامر لغة 6641 وليس اكسس. 


جملة Group 8y‏ تحت ۳٥‏ ھ.rNعہnا۴‏ تعني قم (ما استطعت) 
بتجميع الاباء المتشابهين اي لا تظهر الاب اکثر من مره. 


ولكن هناك (8۷ م6۲01 او تجميع حسب) تحت أسم الأب ورقم 


بالمناسبة العملية الحسابية هي حقل ويسمى Calcualted Field‏ 
أو الحقل الحسابي ومن هذا المنطلق لا نستخدم العمليات الحسابية في 
الجداول بل في الإستعلامات. 


أيدك الآن --- حتى تفهم المنطق من وراء العملية كلها أن ترسم في 
الدفتر جدولا فيه الحقول الخمسة المشار إليها في الإستعلام السابق 
أي تكتب فعلا النتيجة النهائية التي نبحث عنها من هذا الشرح. 


مرة أخرى... 
نريد رقم الأب» إسم الأب» رقم الطفل» إسم الطفل» إجمالي تكلفة 


أعلم أن العملية صعبة شرحا بالكتابةء حبذا لو كنتم أمامي في قاعة 


تدريب لفتحت رؤوسکكم (بسکكين خاص لدي) وصببت فيه المعلومات 
صا 


"= » 


عنه. 


لنكمل الإستعلام ثم نعود مرة أخرى ونحاول الشرح بشكل أكثر 
E ha‏ & 
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إذا حاولت أن تقوم بالعملية (يدويا) فستلاحظ أنك ستضطر إلى إجراء 
عمليات حسابية جانبية لبعض الآباء --- لماذا؟ لأن (مثال) الطفل رقم 
0 ملقوف قام بإجراء أكثر من عملية شراء لأصناف مختلفة -- 
صح؟ 

نحصل على ... ماذا؟ 


الطفل 110 أجرى 5 عمليات شراء --- عند ضرب الكمية في سعر 
الصنقف نحصل على ماذا؟ نعم ......... نحصل على 5 اجماليات 
نوضح اکثر 

الطفل الملقرف 110 


قام بشراء 3 محايات بسعر المحاية 2 ريال الإجمالي 6 ریالات 
قام بشراء 2 مسطرة بسعر المسطرة 4 ريالات الإجمالي 8 رباإل 
قام بشراء 7 أقلام رصاص بسعر القلم 1 ربال الإجمالي 7 ربال 
NR‏ 

فا ترا و فر د کین کول ااا 


المطلوب هو ما دفعه الأب ... أي اب الطفل 110 !!! ما هو؟ طبعا 
كلها هو ما دفعه الأب لقاء مشتريات إبنه 110 


أي هي ناتج جمع 6 و 8 و 7 و ...و 


لان الألحفل الحسابي الذي صنعناه هو عملية حسابية أريدك أن تختار 
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من القائمة وتستبدل (تجميع حسب) ب ۲65510۸ م×ع أي ناتج 


إذا قمت بتنفيذ الإستعلام الآن ستحصل على خطأ لأن الآكسس وال 
SQ‏ لن یستطیعوا عمل (تجمیع 8y‏ م ں٥6۲‏ )للعملیات 
بدون إستخدام قانون اخر للسيد 00۵٩‏ وهو 


Aggregate Functions‏ ر ل أعلم ترجمتھا بالعربیة!!! 


هل من يساعدنا بالترجمة... 


تحياتي»۰۰ 
مرحباء»ء» 


للأح الذي سأل عن (الكمية) أقول له الهدف هنا إجراء 
الحسابات وإذا قام طفل بإجراء عملية شراء لنفس الأصناف 
فهو مستحيل حسب تصميمنا للقاعدة (واللّه يا شباب كلمة 
القاعدة هذي تجيب الحساسية !!) وقد تطرقنا لهذا عندما 
إقترحنا أن يكون هناك (تاريخ الشراء) --- عند إضافة تاريخ 
الشراء يصبح تصممنا للقاعدة خطاً وبحاجة إلى إعادة 
التصميم بفکر مختلف و ورؤية مختلفة. 


وصIil Aggregate Functions JJj‏ وأشكر الأخوة على 


الترخفة (ذوال الاخضصاة)وامل أن تكون:هى. ال حمة العلهة + 
ولا تھا هدا کالوا برک مااهی:. 
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لا تنس أن هذه الدوال خاصة بلغة ا54 ولا علاقة لما 
بالاکسس :.. من يقول لي ماذا يعني هذا؟ وما آهميته؟ 


كل المعادلات الحسابية موجودة في هذه الدوال ومن 
اشهرها... 
--- A۷6وهي‏ المتوسط الحسابي وفي الرياضيات هو 


مجموع الأقيام مقسوما على عددهاعوھe۲ A۷‏ 


gagCount ---‏ العدد أي عدد السجلات في جدول ما --- او 
عدد الاطفال الإنات متلا 


Maxi Uma رoSÎMax‎ --- 

Minimumaaaê JêlMin --- 
Summationgge>aoJlSum --- 

--- كاي الإنحراف المعيlري‏ ¬ټDeviati0 Standard‏ 
الخاص بالإحصاء 

وهکذا.... 


لحل الإستعلام الذي وقفنا عنده: 

نضع الحقول الأربعة التالية في الإستعلام ونختار من قائمة 
عرض (مجامیع اهاه ( 

۴atherNum‏ من جدول الآباء 

۴atherName‏ من جدول الأباء 

UM‏ 50NNمن‏ جدول الأبناء 

sonNameمن‏ جدول الأبناء 


كل الحقول السابقة --- نختار لها إ8 مدهآ أو تجميع 


ح سب 


119 


تم نضيف الحقل الحسابي التالي في العمود الخامس 
ونختار له ۲855S107۸‏ ×۴ للكناية عن عملية حسابية 


sum([Qty ]*[ItemCost]) 


صححوا الأقواس 


لاحظ أن إستخدام دالة --- 51۳ لن أجيب --- من يقول لماذا 
تم إستخدام دالة" Su‏ ؟ ما الفائدة منها؟ 


x! E 1 Ef‏ 2 س E‏ 8 ادا اعت 


اا تکوین إساق يت جدولي حتف اطفاد ي 5 
e‏ رگ تسرف بیاتات | جرون ي منشئ فخ ارحاع: | انكل 


النتاج توع الاستعلامر إعداد الاستعلام 
كافة الجداول ا < ل اعلام 
Father‏ 8 2 
E SonsItem Ttems Sons Father ugız + Father‏ 
چ استعلامة ItemNum ItemNum SonNum Fatherium F‏ 
ItemName SonName FatherName * Sons‏ 
8 کڈ :جدونں Qty ItemGost SonAge FatherAge‏ 
FatherNum‏ 
م استعلامة 
Items‏ & 
uaz : Items‏ 
اسععلام1 
SonsItem‏ & 
du : Sonsîtem E‏ 
استعلام1 
u) *‏ 4 
قل: 3um([TtemGost] *IQty]) SanName SonNum FatherName [e‏ 
Sans Sons :‏ 
الإجمالى: | تجميع حسب تجمیع حسب تجميع حسب تجمیع حسب Expression‏ 
فرز: 
اهار a O a 2 [ 7 5 1 Wi‏ 
المعايير: 
9: 
ul *‏ 4 


2 TEBE Num Lock جاه‎ 
- 0© 7 € 0626 ص‎ 


نوع آخر من الإستعلامات الهامة جدا ويسمى 25 آككهاC‏ 
اوهو عبارة عن جدول وكلمة جدول تعني صفوف 
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وأعمدة وعليه فان هذا النوع من الإستعلامات فيه تثلانة 
حقلين والثالث عملية حسابية» الحقل الأول هو صفوف 
الجدول. الحقل الثاني هو أعمدة الجدولء أما القيمة في 
تقاطع کل صف مع عمود. 


)من يساعدني في شرح كيفية إدراج صور في آي مشاركة ( 
!11 


نفذ الإستعلام التالي: 


أضف جدولي الآباء والأبناء تم إختر من قائمة (نوع الاستعلام 
--- Query|ختر‏ (إستعلام جدوlلJي CrOoSSTab QUEFY‏ ( 


اضف حقل ع٥2۳۴١۲۸عطاج۴‏ من جدول الآباء --- الإجمالي 
(تجميع حسب) وجدولي (عنوان الصف) 


اضف حقل 50١۸13۳٥‏ من جدول الأبناء--- الإجمالي (تجحميع 
حسب) وجدولي (عنوان العمود) 


أضف حقل S0١۳١‏ من جدول الأبناء --- الإجمالي (خ7اC0٤)‏ 
وجدولي (القيمة) 


نفذ الإستعلام... من يشرح لي هذا الإستعلام الرائع؟؟؟!!!! 
لا ینسی أحد منكم (رجاء لا أمرآً) ان يصرف وقتا طویلا بل 
طويلا جدا في ممارسة الإستعلامات --- كل قواعد البيانات 


بعد تنظيم وإنشاء الجداول تعتمد على قوة ووضوح 
الإستعلامات. 
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وقبل الإستمرار في هذه السلسة من الدروس آمل من 
الخمت حل الواحت التالئ لا اكد انك هغاك من داكو ونخاول 


في قائمة إستعلام -- (وهي أهم قائمة) يوجد الخيارات 
التالية: 


استعلام تحدید --- QU r۷‏ )اع وقد قمنا بتطبیقه 
استعلام حدولي --- ۲¥ Q6‏ ۲055135) وقد قمنا بتطبیيقه 
في المثال السابق 


إستعلام إنشاء حدول --- Make-1 abe Query‏ من يشرح 
لي هذا؟ 

إستعلام تحدیث --- Qu‌٥ r۷‏ عمل من يشرح لي هذا؟ 
إستعلام إلحاق --- Query‏ ۹ع‌ممA‏ من يشرح لي هذا؟ 

إستعلام حذف --- Que r۷‏ اع من يشرح لي هذا؟ 


خاص ب ا5 أي خاص بلغة ا5 وفيها ثلاثة أنواع من 
الإستعلامات: 

U ۸10٩۹ توحید‎ 

Pass-1 hroUghaJريرمت‎ 

Data Defi niti0 ^¬ تٽا|نlaڊب تعريف‎ 


من يشرح لي ماذا يحدث عندما نختار أي من الثلاثة 
السابقة؟ لماذا يحدث هذا؟ 


قد يسعفنا الوقت لشرحها بالتفصيل فيما بعد. 
انتظر إجابات... 
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مرحباء»ء» 


قرر صاحب قاعدة البيانات أن يضيف جدولاً خاص 
بالزوجات!!!! 


تشا تھ بفنجان من القهوة وأعود بعد قليل وأريد 
(بمشيئة اللّه) أن أرى إقتراحات لحقول جدول الزوجات 
وكيف يتم الربط.. . لاحظ أن كل أب يمكن أن يكون لديه 
أكثر من زوجة... كما أن صاحب قاعدة البيانات يريد 
حقل لجنسية الزوجة. 


إضافة إلى هذا طلب منا صاحب قاعدة البيانات أن 
نوضح في جدول الأبناء جنس الطفل. 

لا تنسوا أن قواعد البيانات تصمم من قبل فريق 
فکروا... 

مرحباء»ءء 


إجابات رائعة من الأ (-) ما عدا جحزئيات بسيطة». 
وطبعا لا أدري من أين إقترح (جنسية) للطفل e‏ 
واللّه أضحكنى بشدة وهو يحاول إضافة جنسية للطفل 
٩‏ كيف يحدث هذا لا أدري... واضح أنه سريع 


القراءة. 
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اما إجاباته فهي أكثر من رائعة وينقصها ما يلي: 
في الإستعلامات التي تؤدي إلى حذف وتعديل 
وإلحاق سجلات لا يكفي رد الأخ --- (-) بالطبع رده 
د 100 و ف ا و ا 


أن الحذف والإلحاق والتعديل ليس شرطاً أن يكون 
على سجل واحد. .. في إجابة الأخ (-) إستخدم ( =( 
في كافة الشروط W٤8۴‏ وهو صحيح إذا اردنا أن 
نصيف أو نعدړدل أو نحذفی سجلاً واحدا فقط ولكن 
العملية أشمل من هذا حيث انه بتفيير العلامة ( =( 
إلى علامات أخرى مثل أكبر من وأقل من ولا يساوى 
السجلات من خلال تنفيذ امر إستعلام واحد. 


شر للاخ الضاخئ مقا 


أضف جدول الزوجات W۷٥١‏ بالحقول التالية: 
NUm€Wifeنص‏ 2 --- مفتاح أساسي 
iWifeNameص‏ 

مêرWifeAge‎ 

WifeNationality ---‏ وهو موضوعنا الآن 

um ---‏ ۴atherNحقل‏ غریب للربط 


أضف الحقل التالي في جدول الأبناء: 
--- 50N5€Xوھو‏ موضوعنا الآن 


نعود للسيد --- C0۵0‏ ماذا يقول؟ --- أحد القواعد 
والقوانين العامة ينص على: 
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ماذا يعني تحييد اللغة --- يعني وببساطة شديدة 
عدم الإعتماد على ا في قاعدة البياناتء 
لماذا؟؟ 


لملايين الأسباب... 

تسهيل عمليات الإدخال 

تسهيل ترجمة قاعدة البيانات من لغة إلى أخرى 
تلافي أخطاء الكتابة والإملاء --- من يذكر مشكلة 
انتی وانثی وغیرها 

تصغير حجم قاعدة البيانات 


الوا ترئ خقل الخنسية قي دول الزوجات: كرف 
نتعامل مع هذا الحقلء للأسف الطرق التقليدية والتي 
رأيتها في أكثر من قاعدة بيانات هي إدخال النص 
وحيث أن اللغة العربية من اللغات الغنية والثرية جدا 
فی فر ڈانها ترك انها أحداللقات الفللة ذا الى 
تافل مف ضفات لاش واکرک للذک كما انها قن 
اللفات الفة الى تى .موم الفتين وغدرة 


نحمد الله أننا نتعامل مع جدول کله نساء الآن وبالتالي 
سیکون لدا 

سعوديهة 

كويتية 

قطرية 


مصريه 
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ولن يكون لدينا أبدا في هذا الجدول 


إذا مشكلة التذكير والتأنيث وجمع المذكر المعفوس 
(عفواء ترا أنا من أشد العشاق للفة العربية) ولكنه 


مجرد مزاح فقط... 


إنما لمشكلة ما زالت قائمة حتى مع كون الجدول 
بكامله يتعلق بنساء. ما هي المشكلة: 


سعوديهة 
سعوديیه 
لاحظ (الهاء) مقارنة مع (التاء ا --- في علم 
قواعد المانات ها بى خسان مخ فمن كف 


اسفن مدل البانات؟ كيف نكل هذه المشكلة؟ 
اتفال هقی مخ المد 2 600 اغد نا كى 


شكرا سيد --- 0۵٩١‏ الحل هو بإستخدام الجداول 
nllسxclwةTables Help‏ 


والخذاول المتماعدة فن اخفل الخذاول لا ركف 


شر أخطاء الإملاء وتساعدك على تحييد اللغة 
بالكامل» والجحدول المساعد تقتصر مهامه على تغذية 
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الحقول بالنصوص فقط وبهذا تكتب النصوص مرة واحدة 
ناملاء ست ك ولیه الملا ءال قوت 
مله کو الیک کون مکو کی اوو لانت 
الول 


المشكلة الثانية التي تقوم الجداول المساعدة بحلها 
هي عمليات التعديل» لنفترض ان لدينا في جدول 
الزوجات 2 مليون سجل منهم 100 ألف سعودية وتم 
إدخال الجنسية على شكل (سعوودية) خطاً ... ثم 
قررت تعديل هذا الخطأ... لديك حلان... 


إما إدخال يدوي وتعديل 100 آلف سجل يدوياً وهذا 
قطعا إنتحار... 

أو تصميم إستعلام ٥2ل‏ ملا لتحديث بيانات هذا الحقل 
وتغييره من (سعوودية) إلى (سعودية) ولكن لحظة... 


نحن مررنا مرور الكرام على هذا النوع من 
الإستعلامات ... الإستعلامات التي تؤدي إلي إلحاق 
وحذف وتعدیل لأكثر من سجل واحد تتطلب اعلی 
درجات الحذر وتتطلب إجراء نسخ إحتياطية للبيانات 
الأصلية قبل إجراء عملية التعديل لأن أي خطأً في 
الشرط WHE٤R۴٤‏ سیترتب عليه مصائب لا حد لها ولا 
حصر. 


ا الخفن الفا قن غر على واكالف ا 
مفر من إستخدام الجداول المساعدة كعاbة٠‏ pام١۸‏ 
لقرل اللفة وتخدها والفستاقمة هن الندانة فى انناء 
قاعدة بيانات متكاملة ومتماسكة. 
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إنشأ الجدول المساعد التالي: 
National tYNUmM‏ نص 2 -- مفتاح رئیيسي 
iNationalityص‏ 


إحغفظa NationalitieSewl‏ 
اقل البيانات التالية في جدول الجنسيات: 


ماذا نفعل بعد هذا؟ صح !! نربط جدول الجنسيات 
بجدول الزوجات ولكن يتطلب الأمر أولا تعديل الحقل 
if eNationa ty‏ في جدول الزوجات.... لیصبح ماذا؟ 


أجب قبل القراءة... 


نعدJ‏ |lحJa NationalityNum ylJ| WifeNationality‏ 
على هيئة نص وبطول 2 ليصبح حقلا غريبا. 


إربط بین الحقلین Nati 0211۷ N10۳‏ بالسحب من 
جدول Nationalities‏ إلى جدول كمWi۷‏ وضع علامة 
صح على المربعات التلاتة... والعلاقة الآن واحد إلى 


منعدد. 


أضف السجلات التالية في جدول الجنسيات: 
2قطرية 

03کويتية 

4مصرية 

05إماراتىة 

6يمنية 
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07عراقية 
8عمانية 
09بحرينية 
10سورية 


لاحظ أن التهجئة (الإملاء) للجنسيات غير مهم حاليا 
(تحييد اللغة) لان الربط يتم مع رقم الجنسية وليس 
اللضن .وك ال هة شا 


قم بربط جدول الآباء مع جدول الزوجات --- قطعا لن 


ثم أضف السجلات التالية إلى جدول الزوجات:5ع۷۷ 
WifeNum WifeName WifeAge NationalityNum‏ 
FatherNum‏ 

0غادة سعید آل محمد 42 02 4000 

81منیى طلال خالد 22 10 4000 

82سارة خليل الدوسري 36 02 4000 

83مها عبد الرحمن الخليل 19 07 9000 

4سارة سعيد السالم 51 09 6000 

88عفاف محمد اليوسف 39 500001 


واحجب منزلي... 


کیف نربط جنس الطفل؟ ماذا يحل لنا من مشاكل؟ 
كفنا )تلام وخ عدد ال وات لكل أت وعد 
الأطفال؟ 

کم عدد زوجات کل أب من كل جنسية؟ 

کے ا انول لک وط اآغھار وات کا 
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اب؟ 


إسأل نفسك 100 سؤال وأجب عليها وإستمتع بقواعد 
البيانات!!! . 


مرحباء»ء» 


وصلنا إلى حقل جنس الطفل وسمى هذا النوع من 
الحقول (الحقول تنائية القيمة) أي لا يوجد إلا قيمتين 


کر 


وتستطيع عزيزي القارىء أن تطبق نفس الأسلوب 
الذي إتبعناه في حقل الجنسية في جدول الزوجات 
من حيث إنشاء جدول للجنس فيه حقلين رقم الجنس 
ونوعا الجنس وتربط مع جدول لابناء بحقل غريب هو 
رقم الجنس. وهذا مجهد لسجلين فقط (لاحظ ان 
جدول الجنس سيحتوي على سجلين فقط) وبهذا 
تصبح عملية إنشاء جدول وربطه وما الى ذلك مجهدة 
اف رلا ف 

فا و 

ذکر “ آنٹی 

ليل - نهار 

فترة صباحية -- فترة مسائية 

أو في حقول النفي والإثبات مثل: 
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متزوج -- عیر متزوج 
مدخن -- عير مدخن 
عصبي -- عير عصبي 
وهکذا... 


فاننا نستخدم حقول من نوع |8 في ا@5 15 أو 
(نعم/لا ۲۵5/۸0 )في الآأكسس. 


ولكن الحقل في جحدول الأبناء إسمه ×عSonS‏ متلا 
وبهذا تصبح الإجابة بنعم او لا غير منطقية وعليه جرت 
العادة إلى تغيير طريقة تسمية الحقل إلى شيء أكثر 
دقة مثل ان يكون إسم الحقل ٤ا2٣۴۴‏ وبهذا يصبح 
السؤال (انتى؟) وعندها تصبح الإحابة نعم ام لا. 


وعليه لإستعراض الذكور فقط من جدول الأبناء يصبح 
الشرط هو: 

Female=no 

أي الجنس من غير الإناث. 


نترك الآن قاعدة البيانات الخاصة بالعائلة ونقفل 
الآأكسس أو أي برنامج قواعد بيانات آخر. 

وعلى الورق فقط (كتابة فقط) 

کے لی کف رویط الارن کے قاعدة البانات الخاسة 
تال ضف ٤‏ 


مرحباء»» 
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حرام عليكم ... وين الناس؟ وين الشغالين معنا؟ 
المهم أن او ال اوا این 
الهدف أن تكون الإجابة صح!!! 


ممتاز للأخ (-) وسؤال شخصي لك هل تعرف كل هذا 
مما سبق؟ إذا كنت جيدا في قواعد البيانات (مو 
الاكسس 2000 Microsoft SQL| Server‏ --- )وقمت 
بعمل أية مشاريع آو نماذج من قبل... آمل إرسال بريد 
إلكتروني توضح لي فيه خبرتك بالضبط وإذا كان لديك 
في المشاركة في مشاریع حقيقية. آمل ال 
e E LUE‏ 
حالة قبولك ورغبتك ايضا) ستعمل من جهازك من 
منزلك ولن يؤثر عليك شيئا. بالعكس سيكون لديك 
دخل مادي جديد. تحياتي 


أتى وقت السحرر والأمساك ولم أقرأً أي إقتراح لكيفية 
ربط جداول المستوصف (بدون آكسس) على الورق 


انا بالإنتطا! !۱/1 11111111111111111 N‏ ار... 


مرحباء»» 


خاولة دة فتن الآ ی لاقل خالش 
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و اوا د ف ا ل و 


سأكون أول سبب من أسباب تساقط الشعر لديكم ... 
من كثرة التفكير والتمعن... 

يا ناس ... إتركوا النماذج والتقارير والماكروز --- ما يوجد 
في هذه الدروس هو ما یسمی بقواعد البیانات 


والاقک فة لوقت 


سأنتظر.... وأستمتع وأنا أرى كل واحد منكم يتعذب 
في حل المشكلة!!!! 


مرحباء»» 
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الخ (-----) أقترح عليك القرآءة من البداية بهدوء 
وتمعن وروية..نحن لا نتعلم الآأكسس هنا ... نحن 
نتعلم (مفاهيم وأسس قواعد البيانات) ... الحل الذي 
إقترحته هو من ناتج عن تراكم الأخطاء في تعلم 
قواعد البيانات... إذا أردت الإحتراف والحصول على 
مبالغ مالية من قواعد البيانات أقترح أن تعيد النظر 
لتساعد نفسك على نسيان المفاهيم الخاطئة 
وإستبدالها بمفاهيم صحيحة. أما إذا كنت تريد قواعد 
البيانات لإستخداماتك الشخصية فقط أو لقواعد بيانات 
مصغرة للإستخدام من قبل عميل واحد فقط فلا بأس 
كل الطرق جيدة وصحيحة. 


ولأساعدك أكثر أقول لك -- إحفظ القانون الشامل 
التالي: 


Combo Boxessرwll‎ pأlgق‎ 
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مربعات النص5ع×60 ×۲ 


وغيرها كثير من الكائنات --- إحفظ جيدا --- ليس لها 
أي علاقة بقواعد البيانات لأن هذه الكائنات تستخدم 
فقط في( الطبقة الأولى) وهي واجهة المستخدم -- 
نحن نتعلم الآن (الطبقة الثالثة) وهي 82)٤١‏ 
الخاص بقواعد البيانات. 


كافة الكائنات تستخدم على النماذج والتقارير وبهذا 
تصبح النماذج والتقارير والكائنات والماكروز في 
(الآكسس) لا قيمة لها على الإطلاق... أقصد بهذا 
ليست للمحترفين ولكنها جيدة ورائعة للهواة. 


أعد حساباتك مرة أخرى وهذه فرصة جيدة وثمينة إذا 
كنت مبتدئا للحصول على المفاهيم والطرق الصحيحة 
وليس تعميق المفاهيم الخاطئة. 
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مرحباء»ء» 


توقعت الحصول على محاولات أكثر لا أدري هل مع 
بعد الصداع!!! 


وحيث أني قطعت على نفسي وعدا بفض النظر عن 
أية عناصر أخرى فسأكمل وكل أملي أن أنال في هذه 
الأيام والليالي الفضيلة الدعوات الصالحة منكم. 


نعود إلى قاعدة بيانات المستوصف.. 


وآمل حتى في غياب المشاركات --- أن يكون هناك 
من حاول» وقد كنت متأكداآً أنكم لن تصلون إلى الحل 
ولم يكن أصلا الوصول إلى الحل هو الهدف --- الهرف 
هو تعميق مفاهيم وأسس قواعد البيانات من خلال 
توضیح: 


أن تصميم قاعدة بيانات ليس نزهة ورحلة ممتعة 
وسهلة 

ان التصميم يتطلب فكرا وجهدا وفريق عمل 

ان تصميم كل قاعدة يختلف جذريا عن تصميم قاعدة 
بیانات أخری --- حيث أن لكل قاعدة بيانات شخصية 
مستقلة ومنفردة عن أي قاعدة آخری 

أن قاعدة البيانات الواحدة أي نفسها يمكن تصميمها 
بعشرات الطرق المختلفة ودائما يوحد طريقة مثلى او 


136 


أفضل من الطرق الأخرى. 


في جداول قاعدة البيانات الخاصة بالمستوصف لدينا 
مشكلة -- تعالوا نلخص هذه المشكلة: 


بين العيادات والأطباء -- علاقة متعدد إلى متعدد حيث 
ان کل عيادة یدخلھا اکثر من طبیب وکل طبیب يدخل 


بين العيادات والمرضى -- علاقة متعدد إلى متعدد 
حيث ان كل عيادة يدخلها اكثر من مريض وکل مريض 
يزور أكثر من عيادة؟ 


ٻين الأطباء والمرضي -- علاقة متعدد إلى متعدد حيث 
ان کل طبیب یعالج اکثر من مریض وکل مریض يعالجه 


باختصار» العلاقات بين الجداول التلاتة هي علاقة 
متعدد إلى متعدد» ماذا يعني هذا؟ 


يعني (حسب ما تعلمناه) إنشاء تلاتة جداول على 
شکل ۴اط ۲2 ۸٥'ااcمہuل‏ جداول متقاطعة وھذا غیر 
عملي وسيؤدي إلى قاعدة بيانات على شكل 
(سباجيتي) أي متداخلة بشكل خطير مما سيؤثر 
على التماسك والتكامل. 


بالمناسبة المصطلح ااا وهم سباجيتي (أي 


المكرونة الهتداخلة) هو مصظاح علمى ,نس دم قى 
البرمجة. 
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ما هو الحل إذا؟ -- إتصال دولي سريع مع السيد 
0d ---‏ الإجابة هي باستخدام جداول الحركة 
Transaction Tables‏ 


فعظم اعد الانات ده خد جداول ال كة د فال 
نعود إلى (المنطق) ولننسى قواعد البيانات لدقيقة: 


لدینا مستوصف جدید (تم |فتتاحه منذ 5 دقائق) ولدینا 
جدول على الورق فيه بيانات الأطباء ولدينا جدول آخر 
على الورق فيه بيانات العيادات --- المستوصف جديد 
(اي لا یوجد مرضی( 


نحن جميعا في قاعة الا ال مهو دوا 


نعم -- صح -- ننتظر دخول مریض ما !!! بدون دخول أي 
مريض إلى المستوصف سنبقى جميعا في قاعة 
الإستقبال مبتسمين ننتظر حتى نهاية الدوام -- 
بالتعبير العلمي لا يوجد حركة في المستوصف!!! 


حتى لو دخل مريض (ولا يشكو من علة) فقط للإطلاع 
على جاهزية المستوصف وقام بفتح ملف (مجاني ( 
لذا كى ااف وو تم کو هت الى ا 


كل ما حصل أنه ساعدنا في إنشاء الجدول الثالث 
(جدول المرضى) حيث قمنا بإدراج بياناته في الجدول 
(على الورق) -- هذا لا يسمى حركة -- لأن الزائر 
ليس مريض ولم يترتب على زيارته إشغال (تحريك) 
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الط و لاتغا( هرك الفاةة 


لنفترض أننا حصلنا على 1000 مريض كلهم ليسوا 
بحاجة إلى أي علاج سوى التأكد من جاهزية 


المستوصف وقامو بفتح ملفات مجانية لديناء حتى الآن 
لا يوحد حركة في المستوصف... 


نفس الوضع في حالة كون قاعدة البيانات لمحل شراء 
وبيع» حدول للاصناف وجدول للعملاء (فارغ) وحدول 


للبيع --- بدون دخول مشتري لن يكون هناك حركة!! 


قي البنك جدول العملاء وحدول الحسابات وحدول 


وجدول ... بدون دخول عميل ووضع نقود او إجراء 
عملية تحويل فلن يكون هناك حركة. 

في المدرسة جدول للمدرسين وحدول للفصول 
وجدول للمواد بدون وجود طلبة مسجلين بمواد فلن 
کن فال هة 


متى تبدأ الحركة ؟ 
متى تبدأً قاعدة البيانات في التفاعل والعمل ؟ 


من يجيب بعد هذه الإضاءة؟ 


مرحباء»» 
ج نستکما 


نعم جداول الحركة واحدة من ))))))))))))). 
اھ م )))))))))))))))))) واخطر 
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الجداول في قواعد البيانات... 


مرة أخرى كقاعدة عامة (وليست شرطا حيث تخضع 
كل قاعدة بيانات لشروطها الخاصة) نقول كقاعدة 
عامة عندما تلاحظ كثرة العلاقات من نوع متعدد إلى 
متعدد فابدأً بالتفكير ومحاولة الهرب من هذه العلاقة 
باستخدام جداول الحركة. 


وجداول الحركة في أكثر من %90 من الحالات تكون 
عبارة عن جدول واحد فقط يقوم بربط معظم الجداول 


ولأن الحركة في قاعدة بيانات المستوصف هي ناتجة 
عن زيارة لمريض لطبيب في عيادة فإن جدول الحركة 
لدینا سنسميه جدول الزیارات. 


ننشاأً جدول جديد باسم 0۲5ء۷ وفيه الحقول التالية: 
(على الورق...) 


رقم المريض -- حقل غريب يمثل المفتاح الاساسي 
من جدول المرضی 

رقم الطبيب -- حقل غريب يمثل المفتاح الاساسي 
من جدول الأطباء 

رقم العيادة -- حقل غريب يمتل المفتاح الأاساسي 
من جدول العيادات 


وحتى لا يزعل مستر C000‏ فنضيف مفتاح أساسي 
للجدول السابق وهو.. 
رقم الزيارة 
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حلاوة وروعة هذا الجدول الآن انه يعطينا الفرصة 
لإضافة أية معلومات عن ماذا حدث في العيادة بين 
الل وال 


نستكمل الحقول... 

تاريخ الزيارة 

وقت الزيارة 

وصفة العلاج 

تاريخ الخروج 

وقت الخروج 

القيمة التي دفعها المرض 


لاخظ ان كل الحقول الان تشخدت عن مضو 
(الحركة) أي الزيارة ولا علاقة لها بوصف ِ 
المریض کطوله ووزنه وجنسه (هذه كلها موجودة اصلا 
ئي جاول المرضى) ولا شحدت عن الطحت (حستة 
ا ای و 
ولل الى ههه ل فل اة 


ما اروع جداول الحركة في سهولة وحمال حلما 
للمشاكل المعقدة الناتجة عن الإسباحيتي الخاص 
بعلاقات متعدد إلى متعدد. 


ق ی و 


درحة حرارة المرض 
قياس الضغط 


اعراض المرض 
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كل شيء» يتعلق بموضوع الزيارة يسرد هنا 


مشكلة واحدة فقط في جداول الحركة --- وهي أنها 
تعتبر القلب النابض لأي قاعدة بيانات» أمثلة ... أذا 
فقدنا جدول الأطباء ماذا نفعل؟ بسيطة (نوعا ما) نزور 
الأطباء ونحاول إعادة إدخال بياناتهم. 


فقدنا جدول العيادات --- نلف وندور على العيادات مرة 
أاخرى ونجري حصر لبيانات العيادات 


فقدنا جدول المرضي --- لا بأس نحاول الإتصال بهم 
(او ننتظر زیارتهم) ونعید تجمیع بیاناتهم 


أما فقد جدول الحركة فيعتبر مصيبة يترتب عليها الطرد 
من الوظيفة وخسائر فادحة لصاحب المستوصف. 


دائما جدول الحركة هو أخطر الجداول على الإطلاق 
ويتوجب دائما إجراء نسخ إحتياطية لهذا الجدول 
وتحديدذ صلاحيات الدخول للمستخدمين ... بل أكثر من 
هذا في البنوك متلا والتي تستخدم برنامج قواعد 
يراها مدخلي البيانات توضح ماذا فعل كل مدخل 
بيانات في تعامله مع جدول الحركة... لأنه ببساطة 
شديدة لو كان الشخص الذي يدخل بيانات جدول 
الحركة في البنك فاسدآً فسيمكنه بمتهى السهولة 
إضافة بضعة آلاف من الريالات لرصيد حساب صديقه أو 


الثمن المدفوع مقابل جدول الحركة (عندما يحتوي 
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على بيانات مالية) أو معلومات ذات سرية قصوى 
يتوجب أن يقترن بجدول الرقابة كعاbة۲‏ ام٣‏ امه التي 


ولوا الاات انها مخط نك ور من كل مضدة 
قاعدة البيانات. 


من يقول لي الآن كيف نربط الجداول الأربعة الموجودة 
في قاعدة بيانات المستوصف؟؟ 


مرحباء»ء» 


الخ (----) ... كل ما شرحناه هنا ينطبق على كافة 
برامخ قواعد البيانات التي تم إصدارها بعد عام 1970 
ميلادية وكما شرحنا في بداية هذه الدروس أنها 


لقم الأول قواعد اتات لفط السانات ففظ يدوت 
خادم Sev‏ مثل الاكسس و FoxPro 9 ClIiDD€r‏ 
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القسم التاني: قواعد بیانات على شکل خادم S€۲۷۴۲‏ 
ومن أشهرها: 

Microsoft SQL Server 

Oracle 


Sybase 


لافقا من الفتعت م الاوك الى الفم الان ل رة 
کی ا فة كفن الا می الغا هة ا و ها 


أن برامج القسم الثاني لا يوجد فيها مايكروز ولا نماذج 
ولا تقارير ولا شيء من هذا القبيل وقد تنبهت 
الشركات المصممة للبرامج الثلاثة إلى هذه النقطة 
قفنت ا عاف رغفي ال اف الالحافة الب اة 


في تعويض هذا الإحتياج مثل: 


Developer‏ ل وراکل 
MS SQLUEnterpise‏ .... 
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.... Sybase JDevelopment Tools 


وهذه برامج إضافية أو إلحاقية تتعامل مع الخادم 
الأشاشف لتسيط عملبات انشناء التقازير ونما دخ 
الإدخال والإستعلام. 


قبل الخوض في هذه البرامج (من القسم الثاني) لا 
بد من توضيح أهم فروق يميز هذه البرامج عن بعضها 
الكضن: فكو اة دة دة الف هكد هن 
الذنن. بستطهونت الدكول الى الخاذم (إلن قاغدة 
البيانات) في نفس الوقت وفيما يلي بعض الأرقام 
التقريبية وليس للدقة: 


الآكسس مثلا --- في حدود 10 شخاص 

5Q1 --‏ في حدود 30 إلى 70 ألف شخص 
-- ا في حدود 100 إلى 150 ألف شخص 
-- 5ybaseبالملايين‏ 
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ولهذا تجد ان إستخدامات 5/5358 ليست شهيرة في 
التطبيقات الإدارية ويقتصر إستخدامها تقريبا على 
المنشآت المالية الضخمة وأهم مستخدمين لل 
عمsةybدهي‏ البنوك. 


وعليه فإن القفز إلى 258ط5۷ ليس عملي على 
الإطلاق بالنسبة لنا... 


يتبقى لديك الإختيار بين 15S 5Q]‏ و عا٤ة0‏ لشهرتهما 
الكبيرة جدا في بناء التطبيقات الإدارية ويوجد بينهما 
فرق بسیط جدا... 


أن معظم البرامج في السوق هي تطبيقات لشركة 
ميكروسوفت وعليه فان الإنتقال إلى ٤ا٤0۲2‏ سيؤدي 
إلى ضرورة مواجهة والتغلب على بعض المشاكل 
الناتجحة من المؤامة i†yاibiأaمmpدc‏ والدعم الفني 
Technical Support‏ 


146 


من وجهة نظري أن ا5۵ 15 يوجد له في السوق 
کتب أکثر» يوجد له دعم فني عالي وسريع من قبل 
شركة ميكروسوفت ولا يوحد مشاكل في الموائمة. 


بناء على الإضاءات السابقة أرى والرأي خاص لكل 


شخص ويتبع ذوقه وطریقته في التعلم... 


تعلم الثلاثة مع بعضهما البعض عملية شبه مستحيلة 
وتستنزف طاقات وجهد وأموال لا داعي لها وعليه 
يتوجب الأمر التركيز على واحد منها فقط. 


صرف بضعة أسابيع للإطلاع على كل خادم من الثلاثة 
السابقة لتذوق كيفية عمله وتبین نقاط قوته وضعفه 
(مثال 0۲2٤٤‏ أقوى من‌اS۵‏ ۷15) في نواحي الأمان 
والسرية مثلا وهكذا... كل الفكرة من هذه الخطوة هو 
کشو جاخ الخوف والرهة من هذخ ارامح التلانة 
والإطلاع على طريقة عملهم وستفاجأ ان التشابهه 
بينهم عالي جدا جدا. 
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بعد (بضعة أسابيع) من التذوق والمحاولة والتجربة يتم 
التركيز على واحد منهم بقوة وشدة (وهذا ما فعلته أنا 
مثلا) وقد إخترت ا5۵ 15 بعد إستنزاف دام لسنة 


تقریبا في تذوق كلا من 021€ و Syb25€.‏ 


ولگن..: 


مشكلة M5 SQ)‏ انه لا يوجد معه أية برامج إلحاقية 
قوية تساعد على إنشاء نماذج الإدخال وتقارير الإخراج 
وغیرها وبرنامج ٤ءأ۲م۲ع‌ا"ع‏ الملحق به يساعد قي 
عملیات أخرى ذات قوة عالية جدا مٹJ User Defined‏ 
Stored Procedures Ji dJiSgFunctions‏ وقد 
نتطرق لها لاحقا عند شرح بضعة دروس عن تطبيقات 
قواعد البيانات على الإنترنت. 


التمن الذي ستدفعه مقابل إختيارك ا5۵ 15 هو تعلم 
لغة أخرى تساعد على بناء نماذج الإدخال وتقارير 
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الإخراج وأبسط هذەه البرامج FrontPage lew,‏ و 
AP.Netلتطبیقات‏ الإنترنت و ۷8.۸6 لتطبیقات 
Server.‏ ientا€وستصدم‏ وتفاجأً عندما تری أن کل ما 
تعلمته في نماذج وتقارير الأكسس هو نفسه تقريبا 
موجود في هذه اللغات !!! وهنا تكمن روعة وقوة 
شركة ميكروسوفت في أن ما تتعلمه يفيدك دائما في 


مرحلة أخرى. 


يتبقى نقطة واحدة فقط لمساعدتك على إتخاذ القرار 
وهي أن الإنتقال من الآأكسس إلى ا5 15 أو 
اليس نزهة على الإطلاق !!! هو أشبه بالخروج 
من غرفة دافئة رومانسية إلى عاصفة رعدية وتلوج 


هذه النقلة تتطلب تصميما شديدا وعرقا وتعبا في 
البداية وسهر ليالي وما إلى ذلك»» يجب أن تصبر على 
هذا الأرق والتعب لعدة شهور حتى تبدأً مرحلة 
الإنتقال وتبدأ في تذوق طعم وحلاوة هذه البرامج. 


149 


مرحباء»ءء 


نعم --- أصبح ربط الجداول الأساسية الثلاتة سملا 
للغاية الآن من خلال جدول الحركة الذي قمنا بانشائه 
وأصبحت كل العلاقة من النوع المفضل وهي واحد 
إلى متعدد. 


مازال لدينا الكثير ... بل الكثير جدا لتعلمه وشرحه... 
ولكن بدا ضيق الوقت يطبق على انفاسي بشدة ... 
حيث سأتوجه إلى مكة المكرمة غدا الخميس ويومي 
السبت والأحد سأكون في إجتماعات عمل في 
مدينتي الدمام والخبر لأعود إلى الرياض في نهاية 
الأسبوع القادم. 


سأحاول قدر إستطاعتي التواصل معكم ومع المنتديات 
الاخرى... 


ولكني سأقوم بالتركيز على أسئلة المسابقة التي 
طرحتها من قبل وكذلك على الوعود التي قطعتها 
على نفسي في مساعدة بعض الاخوة والاخوات 
على بناء بضعة قواعد بيانات. ولعل الله يسمل لنا 
إكمال هذه الدروس. 
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هذه الليالي الفضيلة والمباركة وبالذات في العشر 
الأواخر وليلة القدر دعوات صادقة من أعماقكم بالذات 
ا و 


ملاحظة. 
طرح الاخ Ml as۲‏ {nterneا‏ سوال ھو: 
لماذا أتعلم قواعد البيانات 


مرحباء»» 
أي جواب لا يكون على الصيغة التالية فهو خطاً %100 !!! 


أتعلم قواعد البيانات لتحقيق رافد مالي جديد» بعبارة أخرى إذا كان الهدف غير 
تحقيق مكسب مادي فنصيحتي التوقف فورا عن تعلم قواعد البيانات وعدم 
إضاعة الوقت. 


اذا الجواب الصحيح والوحيد هو تحقيق مكاسب مالية وأية أجابات أخرى لا 
معنی لها.. 


0 


وحتى لا يغضب مني البعض مثل ما حدث في بعض المؤتمرات أ 


التالي : 
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شخص يريد أن ينال إعجاب زوجته أو أخيه أو يستعرض أمام إبن عمه أو 
صديقه» وهذه الشريحة أنصحها بإستكمال تعلم الأكسس وكذلك وضع الأسئلة 
في المنتديات وخلال بضعة أسابيع أو شهور سيكون قادرا على إنتزاع 
الإعجاب من أقاربه ومعارفه من خلال ترقيص بعض النماذج وتلوين بعض 
الأزرار وطباعة التقارير المبروزة. قطعا لا أتهكم ولا أسخر وإنما من يريد 
الإعجاب من الآخرين (فقط) فهذا هدفه وهذا طريقه ولا عيب في هذا 
وصدقوني لقد رأيت الكثير من الأسئلة في منتدى الآكسس يسألون عن كيفية 
إقفال نموذج بشكل راقص أو تدريجي أو ... !!!!!!!!!! 


استظلي أيضا من يريد أن ينال رنه في العمل اغجاب 

ا ستثني من يريد أن يقدم الواجبات والإختبارات لينجح فقط ومن ثم ينسى أبو 
قواعد البيانات وأهلها وما أكثر وما أضخم هذه الشريحة. 

اس ستثني أيضا من يريد أن يصمم قاعدة بيانات تستخدم من قبل شخص واحد 
قط اکرر خض و احه فط لا أك 


كل من سبق أقول لهم إستمروا في تعلم الأكسس وإستمروا بوضع الأسئلة في 
المنتديات وستجدون الكثير من الإجابات ولا باس بدورة أو دورتين تدريبيتين 
مخفضتين لتأكيد المفاهيم الخاصة بالآكسس أو ما شابهه الآكسس وخلال فترة 
قصيرة ستتمكنون من تحقيق أحلامكم من خلال إنتزاع إعجاب الآخرين وقد 
تقفزون حاجزا واحدا ويفتح الله عليكم من خلال بيع برامج الإستخدام الواحد 
(أي من قبل شخص واحد) مثل محل لتأجير الأشرطة أو محل لتأجير 
السيارات أو ما شابه ذلك (و طبعا هذا احتمال ضعيف) ولكن الإحتمال قائم أن 
تبيع برنامج أو إثنين. كما أن لدى هذه الشرائح فرص لتصميم برامج لطلبة 
الكليات والمعاهد مقابل مبالغ مادية او تقديم دروس خصوصية أو فتح موقع 
مبسط بإشتراكات لشرح قواعد البيانات لهم. 


آمل من الشرائح السابقة مغادرة قطار قواعد البيانات في هذه المحطة متمنين 
لهم رحلة سعيدة. 


الشريحة التي تريد تحقيق مكاسب مالية (حقيقية) الرجاء البقاء في مقاعدكم 
إستعذادا للدنطلدق إلى المحطة التالية 
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لطا ار تع ارو كرس اة ر 


الرجاء ربط الأحزمة. 


تحیاتی»›»»› 


مرحباء»» 


للمتابعين معنا والباحثين عن تحقيق مكاسب مالية أقول لهم» جهزوا قلم 
رصاص جديد ونبدأً بالكتابة مرة أخرى. 


سیکون الاکسس ومثله من البرامج Clipper gs FoxPro Jn‏ ڪ dBase‏ 
وغيرهم أدوات للتعلم من حين لآخر --- فقط أدوات للمساعدة على التعلم. 


في الدروس الأولية تحدتنا أنه لا يوجد شيء اسمه نماذج ولا تقاریر ولا 
مايكروز في قواعد البيانات وقمنا بالتركيز على العمود الفقري لأي برنامج 
قواعد بيانات وهو الجداول والإستعلامات فقط وطبعا هذا مشكلةء لأن قواعد 
البيانات بحاجة (فعلاً) إلى نماذج وإلى تقارير وخلافه. هذه أول مشكلة -- 
عفوا --- أول مصيبة وأول عقبة حقيقة في طريق الإحتراف. 


كيف نصنع النماذج والتقارير ومن أين وكيف؟ هذه الطبقة الأولى !! من 
يتذدکر؟ 


رفضنا الآكسس وغيره من البرامج المشابهة للمشاكل التالية: 
Scalability‏ 

Availability 

Simplicity 
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Server Oriented 
من یذکر ما سبق؟؟؟‎ 


y)زازاهاهء؟‏ وتعني قابلية القياس» أو القياس للتبسيط وهي تعني أن قاعدة 
البيانات تعمل بنفس الكفاءة ونفس القوة بغض النظر عن عدد الجداول أو عدد 
السجلات أو عدد المتعاملين مع القاعدة في نفس الوقت. والمصطلح من الفعل 
ماهءS ۲١‏ أي يغير المقاس متل المقياس المستخدم في الخرائط وغيرها. 


Availability‏ وتعني التواجد أي أن قاعدة البيانات دائما وأبدا متواجدة 
ومتوفرة ولا ينقطع الإتصال بها تحت أي ظرف وعليه إذا أراد صاحب 
لرك له غ عو انح ارت الك رر نن لول د00 
قاعدة البيانات متعطلة. 


Simplicity‏ وهي بساطة وسهولة التعامل مع برنامج قاعدة البيانات وهنا 
اللاأكسس أفضل بكثير من غيره» ولكننا سنضحي بهذه الميزة للحصول على 
ميزات أفضل. 


Server Oriented‏ أي أن قاعدة البيانات تعمل على شكل (بث) 

Br sti2£‏ للدخول إلى الخادم وليس على شكل ملف منفصل كما هو 
الحال مع الآكسس. بعبارة أخری ملف 58« وهو إختآفصlر Microsoft‏ 
Data B6‏ عبارة عن ملف منفصل متل أي ملف آخر نصي أو وثيقة أو 

غیره يتعامل مع محرك ,اعم لتنفیذ أوامر 8Q1‏ بشکل مبسط ولا یعمل 
علی شکل ۲ع۲۷ع$ خادم. 


بعد تبسيط المصطلحات السابقة ننتقل مرة أخرى إلى درس قديم بدأناه في بداية 
هذه السلسة وهر معا و إع۷إمS‏ نعيد مرة أخرى: 


ها هو الجهاز الذي يتعامل مع الطبقة الأولى ويحتوي بالدرجة الأولى 
على نماذج الإدخال والإخراج. 
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S؟Sعإ۷عإ هو الجهاز الحاوي لبرنامج قواعد البيانات على شكل‎ Serve 
وكذلك على قاعدة البيانات تفسها التي تحتوي على الجداول والإستعلامات.‎ 
ماذا يعني هذا؟‎ 


أن الخادم يستطيع أن يخدم أكثر من قاعدة بيانات في نفس الوقت ومن خلال 
تفن اترك 

وینطبق علی هذا 

Micrsoft SQL Server 


Oracle Server 
Sybase Server 


ولأن الخادم عليه قواعد البيانات فهو يمثل الطبقة الثالثة. 
كما قلنا سابقا دعونا من الطبقة الثانية حاليا. 


مرة اخرى... 


e OE E a E gE 
وإنطلقنا‎ Availability YY» Scalability IY pey bY aig Server pدlخ‎ 
إلى أنه يوجد في السوق 3 أنواع من الخادمات.‎ 


وقد شرحت الفرق بين الخادمات الثلاثة في منتدى MS SQL Server‏ وأعيد 
هنا مرة أآخرى» أهم فرق بين هذه الخادمات هو عدد مستخدمي الخادم في نفس 


الوقت٠‏ 
مثال: 
5ع عدد المستخدمين في نفس الوقت 15 تقريبا (وضعته هنا للمقارنة 
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MS Q1‏ بالمتوسط عشرات الآلاف مستخدم في نفي الوقت 
6 بالمتوسط بالملایین 


لاحظ أن في الأكسس عدد المستخدمين الزين يعملون على ملف M58‏ في 
نفس الوقت (أي قاعدة بيانات واخدة فقط) بينما في الخادمات الثلاتة فإن العدد 
سيوز ع على عدد قواعد البيانات الموجودة على الخادم. 


مثال آخر: إذا وضعت 290 قاعدة بيانات على خادم 1S SQ]‏ فإن عدد 
المستخدمين (في نفس الوقت) سيقسم على عدد قواعد البيانات وطبعا ليس 
شرطا ففى حالة أنه لا يوجد مستخدمين على 100 قاعدة بيانات متلا فإن العدد 
كو ا انات ري 


بعبارة أخرى في الآأكسس نقيس على قاعدة واحدة بينما في الخادمات تقيس 
على عدد المستخدمين لطاقة الخادم نفسه. لا نحتاج أكثر من هذا ولن ندخل في 
تقنيات معفدة. 


الخلاصة هي ا الخادمات الثلاثة تدعم أعدادا هائلة جدا وكما ترى فان 

Sybase‏ يدعم أعدادا بمئات الألوف بل تصل ل الملايين ویستخدم فقط 
في البنوك بالدرجة الأولى. 

ذا Sybase‏ قوته في حجم المستخدمين وكذللك في نواحي السرية 


«Security‏ وطبعا أقترح عليكم جميعا بعدم تعلم 6ا2لS»‏ من يقول لي 
لماذ؟ أين الأذكياء؟ 


مستر عاع ج0۲ يأتي في المرابة الثانية من حيث 86611٣۷‏ وعدد 


ويقع ا54 15 في المرتبة الثالثة. 
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من تختار؟ ORACLE‏ أو MS SQ)‏ ولماذا؟ طبعا تعلم الإثنين (عفوا) 
غباء !!! حيث يتطلب الأمر احتراف أحدهما وأخذ فكرة عامة عن الآخرء 
ومحدتكم أحد هؤلاء الأغبياء حيث أضعت سنتين تقريبا وكانت غلطة. 


أنتظر إجابة على السؤالين المطروحين؟ 


ٍ_  ؟ال‎ Syطچ2ئsم لماذا‎ 
؟MS‎ SQL ¢ ORACLE رlتخi‎ Il 


أنتظر بضعة إجابات... 


تحیاتی›»»› 


مرحباء»» 


أشكر كلا من الأخ --- وكذلك الأخ -_- على تفاعلهما وردهما الرائع بل 
الرائع جدا. 


صحيح لن يتصل بك أحداً لتصميم قاعدة بيانات eء2طy‏ (إلا بمعجزة) 
وسبب ذلاك Sybase jİ‏ تستخدم من قبل الشركات الضخمة لتصميم قواعد 
بيانات مفتوحة وكلمة مفتوحة تحتاج إلى شرح سريع. 

عند تصميم قاعدة بيانات لديك إختياران لا ثالث لهما: 


الأول: تصميم قاعدة بيانات تخدم منشأة (شركة مؤسسة وزارة إلخ) واحدة 
فقط فمتلا بمقدورك تصميم قاعدة بيانات لشركة تأجير سيارات., في هذا 
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الإختيار أنت تصمم قاعدة البيانات لتخدم هذه المنشأة فقط, عندما تتصل بك 
شركة تأجير سيارات أخرى مختلفة فإنك تقوم بتصميم قاعدة بيانات أخرى 
مختلفة تصلح لإستخدامات هذه الشركة فقط. بعبارة أخرى أصبح لديك 
قاعدتين للبيانات كلاهما يعملان لخدمة شركة تأجير سيارات وقد يتشابهان 
في بعض المكونات ولكنهما يؤديان خدمات مختلفة تصلح لكل شركة على 
حدة. مثال هذا أن تفصل توبا أو بدلة أو فستان لكل عميل على مقاسه وحسب 
رغباته. هذا إسمه النوع المغلق. 


الثاني تصميم قاعدة بیانات تصلح للجميع فتقوم بتصميم قاعدة بيانات لتأجير 
السيارات وتعمل منها آلاف النسخ وتبيعها في السوق لكل راغب في الشراء. 
وهذا هو النوع المفتوح. مثل تفصيل ثياب وبدل وفساتين وتوزيعها في السوق 
وكل من يقوم بالشراء يجري بعض التعديلات 


يقومون بتصميم قواعد بيانات هائلة الحجم للمنشآت المالية في العالم بإستخدام 
8y‏ وعليه فإن أقصى امالك واحلامك في 256طر؟ أن تصبح 
موظفا في أحد هذه الشركات وتصبح فردا في أحد فرق العمل لديها للمشاركة 
في تصميم أحد قواعد البيانات هذه. 


معظم (إن لم يكن كافة) قواعد البيانات في عالمنا العربي المستخدمة في 
البنوك ومؤسسات النقد وشركات الأسهم وغيرها تستخدم قواعد بيانات 


مصممة من قبل برنامج ٥ء2‏ طر5 وكذلك تم تصميمها من قبل شركات في 
امریکا واروبا. 


هذا من وجهة نظري الشخصية يغلق باب ٥2ط‏ إلا من يريد منكم أن 
ا دار ین او ی و 
مasطSy‏ فآمل منه أن يبدا في الموقع التالي "256.0 W۷۷۷ .S/(‏ 


الفرق بين ماع0۲ و اهS 18S‏ ما زال شاسعا وقد سألت هذا السؤال عدة 


مرات منذ بضعة سنوات في محفل رسمي وکانت الإجابات كلها ماعa©‏ 
دون تردد !! وحينها كان عامة0 عشرات الأضعاف متفوقا على NMS‏ 
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ا من كافة الجهات ومع ذلك نصحت الحضور بالتوجه فوراً إلى MS‏ 
9Q‏ وكانت علامات الدهشة بادية على محيا الجميع !!! 


حتى هذه اللحظة مازال عاعه0۲ أفضل من الناحية التقنية ومازال أفضل من 
ناحية 56٥٣١۷‏ ولكن شركة مايكروسوفت تتمتع ببضعة خصال تجعل من 
إقتراحي بإستخدام )8۵ 18 مرجحا بشکل أكبر»ء فيما يلي بعضا من هذه 


أقتبس من الأخ -- -- سيطرة هذه الشركة على سوق البرمجيات 

قوة الدعم الفني لشركة ميكروسوف تفوق الدعم الفني ل ٥امج0۲‏ بمئات 
الأضعاف 

سرعة تطور ا5۵ ۸5 تفوق سرعة تطور ٥امج0۲‏ بشکل کبير وسریع 
وأرى آنه خلال بضعة سنوات سيتفوق ا8۵ ۸S‏ على ٥اع0۲۵‏ وبشکل 
تكلفة إنتاج قاعدة بيانات بإستخدام ۸S 8Q1‏ أرخص بكثير من ماج0 
ityاCompatii‏ أو التوافق بين البرمجيات يرجح كفة 08S SQ)‏ لتفاعلها 
من البرامج الشهيرة بشكل أفضل بكثير من ماج0 

سعر ترخيص S۵1‏ ۱8 أقل بمراحل عديدة من عاcھ©0‏ 


وبالمناسبة فليس لي علاقة لا من قريب ولا من بعيد بهذه الشركات لأفضل 
أحدهما على الأخرى (وياليت كان لي هذا للحصول على نسبة مقابل هذه 
التوصيات !!!). 


وطبعا أعيد مرة أخرى وآمل التركيز أن كل ما نشرحه هنا ونتحدث عنه 
ينطبق على الخادمات الثلاث اlلشkيرة Syabse‏ ڍ Oracle‏ ڪ MS SQL‏ 
حيث أننا هنا نتكلم عن قواعد البيانات ولا نتحدث عن البرامج المستخدمة في 
تصميم وتطوير قواعد البيانات. 


الإختيار مناط بك في النهاية. أنت تقرر ماذا تريد أن تستخدم» وكل ما نقوله 
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كانت فا من الاق اة ر اة فط وهی :كف فوم تاشاء ناد 
الإدخال والإخراج والخادمات لا تدعم هذه الخدمة. 


تنبهت الشركات الثلاث إلى هذه المشكلة حديتا (منذ بضعة سنوات) وكان 
قصب السبق لشركة عاعج0۲ في إنتاجها برامج إلحاقية للمساعدة على إنشاء 
نماذج الإدخال والإخراج. 


وكقاعدة عامة فان هذه البرامج الإلحاقية من قبل الشركات الثلاث يو جد فیها 
الكثير بل الكثير جدا من التعقيد والمشاكل و ۷†أاأطأأةم هع أي التوافق 
كما أن معظم هذہ البرامج الإلحاقیة کان موجھا إلى 86۲۷6۲ ٣٥ا٥‏ ولیس 
إلى الإنترنت وهو درستا القادم بمشئية اله. 


خلاصة القول أن البرامج الإلحاقية لم ولن (من وجهة نظر شخصية) تحقق 
الأمل المطلوب منها لإنشاء واجهات إستخدام حقيقية (نماذج إدخال وإخراج) 
وعملية وعليه فإني لا أرى في هذه البرامج الإلحاقية أي مساعدة عملية 
لمتطلبات السوق. 


جهة أخرى لا تنسى أن هذه هي الطبقة الأولى. 


کک ا TS‏ 


تحیاتی»›»»› 
مرحباء»» 


صفحة خاصة منفصلة فى الدة ان إسمه (المشاكل الأساسية 
في في الدفتر ضع عنو ) ( 
وسنسرد في هذه الصفحة كافة المشاكل التي نحتاج إلى حلول لها. 
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حتى هذه اللحظة لدينا مشكلة أساسية واحدة وهي كيف نصمم نماذج الإدخال 
والإخراج عندما نستغني عن برامج بسيطة مثل الأكسس وغيره ونتوجه إلى 
الخادمات .Oracle yı MS SQL Jîn‏ 


مرة أخرى... لا يوجد لدينا طريقة لإنشاء نماذج الإدخال والإخراج. 


ترا ا ارون ا ي ت ا و ار کر ع 


Client 
Server 


أول شي ... ٠6ا٥‏ عندما نسمعها أو نقرأها نتخيل الطبقة الأولى ويوجد 
فيها نماذج الإدخال والإخراج. 


e٣‏ عندما نسمعها أو نقرأها نتخيل الطبقة الثالثة ويوجد فيها قاعدة 
(قواعد) البيانات (قواعد) لأننا على خادم. وقاعدة البيانات حسب ما تعلمناه 


نقطة أخرى في غاية الأهمية --- ركز --- لأء ركز بشدةء المسافة بين 
Client‏ و Server‏ هي آلاف الکیلومترات !!! 

سنتخيل أن جهاز ها موجود في شقة ما في عمارة ما في مدينة مكة 
المكرمة» و 56۲۷8٣‏ موحود في شقة ما في عمارة ما في مدينة لوس 
أنجلوس !! المسافة مين يعرف أكثر من 17000 كيلومتر !!! 


كذلك سنتخيل أن جهاز مدخل البيانات موجود في شفة ما في عمارة ما في 
مدينة دبي. 
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قاعدة البيانات على الخادم في لوس أنجلوس فيها جدول صغير ببضعة حقول 
وبضعة عشرات من السجلات. بمعنى آخر مدخل بیانات واحد يكفي. 


الأجهزة الثلاثة كلها مرتبطة بالإنترنت. 


مدخل البيانات في مدينة دبي (مع فنجان من القهوة) يدخل إلى جهازه ويقوم 
بادخال بضعة بيانات إلى القاعدة !!! 


درگ .ھا الذي حدث؟ 


لإدخال بیانات إلى قاعدة ما نستخدم الأمر ٥٣ا‏ اs6ہ|‏ (لا مشكلة إن كنت 
لاتتذكر فهذا ليس هو الموضوع)...نركز عندما يضغط مدخل البيانات زر 
الإدخال تحصل آلاف العمليات التي لا نراها!!! من يستطيع أن يتقمعص 
(مغمضا عینیه) لعدة دقائق أنك أنت جملة أ 6ئ١|‏ وبعد إرسالك من خلال 
زر الإدخال بدأت رحلة شاقة أكثر من 18000 كيلومتر من دبي متجها إلى 
لوس آنجلوس !!! 


مدخل البيانات أرسل سطراً واحدأ عبارة عن جملة ۸56۲| لإدخال سجل 
واحد فقط في قاعدة بيانات بعيدة جدا... 


لا يوجد شخص في العالم (إلا قلة) يستطيع أن يحدد مسبقا رحلة هذه الجملة 
يستخدمها ١ء۸6۲٥ه14)‏ أكثر من المبرمجين والمصممين. 


نحن كمبر مجين ومصممين ماذا يهمنا من هذه الرحلة؟ من يقول؟ 


يهمنا التالي: 
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سر عة نفاذ الجملة من الجهاز في دبي إلى كرت الموديم إلى الخط الهاتفي في 
ان المقسم في دبي إلى مزود الخدمة في دبي إلى ¥2yةW‏ 6اه الخاصة 
في دبي إلى أي كيبل بحري إلى أوروبا إلى الكيبل البحري في المحيط 
الأطلنطي إلى مدينة نيويورك إلى |۳١‏ إلى مقسم في لوس أنجلوس إلى . 

إلى ... إلى ... إلى كرت الشكبة في عمارتنا إلى الجهاز إلى قاعدة البيانات 
إلى الجدول ... واووووووووو---إستراحة رحلة طويلة... 


قلنا ما يهمنا بالدرجة الأولى هو ((((سرعة)))) تتفيذ الجملة !!!! 
حتى السرعة غير كافية... 


في الإنترنت علم قائم بذاته یتطلب شرحا ثقافیا مستفیضا (وقد یکون أحد 
دروسنا یوما ما) وهو ۲٤٥۲/1۲‏ وهي أحد آهم بروتوكولات الإنترنت... 
مشكلة TCP/IP‏ الأساسية أنها ل تضمن نفل البيانات من جهاز لآخر حول 
الكرة الأرضية وعليه لدينا مشكلة جديدة وهي من يضمن أن السجل قد دخل 
في قاعدة البيانات... والغريب أن معظم مصممي قواعد البيانات لا يلتفتون 
لهذه النقطة !!!! 


نعود إلى صديقنا في مكة المكرمة وهو مجرد زائر يريد أن يطلع على بيانات 
القاعدة فيقوم بتنفيذ جملة ٤ءع1ع$‏ للحصول على بيانات ما... 


ركز معي مرة أخرى من فضلك... لنفترض أن قاعدة البيانات فيها إسم 
الموظف» إسم أب الموظف»إسم عائلة الموظف. 


سنفترض أن مدخل البيانات في دبي (موظف نشيط) وقام بإدخال 3 ملايين 
سجل في قاعدة البيانات. 


الصديق في مكة المكرمة يريد أن يحصل على جدول مرتبا أبجديا حسب 
العائلة لكافة سجلات قاعدة البيانات... بسيط... ننفذ له جملة )ءم[ع؟ ومن ثم 
ن ا الاب بإاسم العائلة مع فراع بين کل منهما لیراه کإاسم کامل 
ونقوم بالتنفيد. 
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TS‏ ولكن لحظة ماذا حدث في هذا الجملة البسيطة 


أخونا في دبي كان لديه مشكلة السرعة وضمان دخول السجل في القاعدة بينما 
E‏ .. المصيبة هي أن هذا 
ال ا ا و 
لماذا؟ لأن الصفحة في مكة المكرمة ستأخذ ما لا يقل عن نصف ساعة لتفتح 
!!! حتى مع سرعة إتصال عالية جداً بل سيقوم الأخ في مكة المكرمة بترك 
الموقع والذهاب إلى موقع آخر أسرع وأفضل من موقعنا. 


إذهب إلى 00طه۲ وفي خانة البحث إكتب ٥٠ء1[‏ وإنظر إلى الرقم الذي 
يوضح عدد النتائج ستجده أكثر من 160 مليون سجل» حتى في إتصال هاتفي 
بطيء جدا أرسل لك 160 0 مليون سجل في بضعة تواني !!! كيف 
e Ig‏ 


من يقول لي كيف هذا؟ ولماذا؟ أين الذين يدرسون؟ 

يكفيني بضعة إجابات لأني واثق ان الدروس التالية ستجعل الكثير يعودون إلى 
منطقة الأمان وإلى طرقهم القديمة.. الكثير سيعود إلى حبيبة قلبه الآكسس قائلا 
لنفسه بلاش صداع !! وله الحق بل كل الحق ولكنه لن يربح ريالا واحدا طيلة 
حیاته!!! 

من يجیب؟ 

تحياتي»۰۰ 

مرحباء»» 


إستمروا في التفكير للحصول على إجابة السؤال السابق. 
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نواصل البحث في المشاكل... 


عندما تطلبك شركة ما لتصميم أي برنامج يتصل بقاعدة بيانات فهناك تلاثة 
إحتمالات لا رابع لهما: 


الإحتمال الأول: 

شركة في مدنية الرياض في السعوديةء يوجد فيها 30 حاسب آلي مرتبطة 
جميعها بشبكةء هذا السيناريو يسمى 4١‏ اي شبكة محلية. ببساطة شديدة 
تختار أي جهاز منها وتقول هذا هو الخادم امام؟ ثم تختار جهاز آخر 
(حسب تصميمك) وتقول هذا الجهاز ھgy Backup‏ أي الرديف» في حالة فشل 
الخادم مم الأساسي تنتقل العمليات إلى مں)ءه8 لحين إصلاح الخادم 
وبهذا لا يكون هناك إنقطاع. ثم تختار جهاز ثالث وتقول هذا هو الجهاز 
المخصص لنماذج الإدخال ويستخدم من قبل مدخلي البيانات» تضع الجداول 
والإستعلامات عل «Server‏ تضع النمادج غل جهاز الطبقة الأولىء: ویتبقی 
لك 27 جهاز كمستخدمين. هذا السيناريو أو الإحتمال الأول يسمى اعم )ہ1 
لاحظ وركز إنترانت وليس إنترنت !!! 


الإحتمال الثانى: 

نفس الشركة السابقة قامت بإفتتاح فرع في مدينة جدة ويوجد في الفرع 15 
جهاز مرتبطين بشبكة محلية ...1,۸١N‏ هههههه--- أهلاً بك في عالم 
التوهان!!! هذا السيناريو أو الإحتمال يسمى 0۸١‏ ومشكلته الآن تكمن في 
كيفية الربط بين الإدارة العامة في الرياض والفرع في جدة!!! والحلول ٠‏ 
المطروحة هي بإستخدم الخط الهاتفي (وهذا تخلف آسف حل يعود ألى 
عشرات السنين إلى الوراء) أو بإستخدام دوائر مؤجرة تسمى 5١‏ 5. 


الإحتمال الثالث. 
في مدينة لاهور في باكستان... الان لا يوجد إلا حل واحد 
(إقتص اددي) وهو الإنترنت!! 
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لا تقلق !!! 


المشاكل السانفة لا ذل نا قها كمضممنن قر عة الياتات هذه مشاكل 
مصممي الشبكات... نحن نجلس في إجتماعنا نتلذذ بفناجين القهوة ونستمتع 
بينما مصممي الشبكات يتضاربون بالأفكار والأيدي ويناقشون الإقتراحات 
الول ال ار فول كة 


دورنا وعذابنا يبدأ بعد تصميم الشبكة حيث أن برمجة وتصميم قاعدة البيانات 
يختلف جذريا بإختلاف شكل رطمهإع همه للشبكة. 


كل ما يهمنا في هذه الموضوع هو سرد مشكلة أساسية أخرى وهي كيف نربط 
بين واجهات الإستخدام (الطبقة الأولى) وقاعدة البيانات (الطبقة الثالثة) مرورا 
بطبقة المنطق (الطبقة الثازهة) ليس الهدف هو الربط فقط ركز ..... الهدف هو 
الربط بطريقة إقتصادية. كل الناس يستطيعون أن يربطوا بين النماذج 
والقاعدة ولكن قلة ضئيلة جدا تستطيع عمل هذا بشكل إقتصادي. 


قدرتك على الربط بشكل إقتصادي يشكل الفرق الأساسي بين من 
NE ae‏ الربط الغير إقتصادي مكلف 
وبهذا د اع المرردن آي ا ر ن ا ا ع ي اول 
تعالوا الدروس إيلاما وتوجعيا لكل من يريد أن يحقق مبالغ مالية من 
قواعد البيانات» هذا الدرس مؤلم بشدة وأعنى انه سيؤدي إلى أن نخسر 
مجمو عة أخرى كبيرة خشية إقتحام هذا العالم. 


أو لا: لتصميم الواجهات (النماذج والتقارير والإحصائيات) نحتاج ا أداة 
مختلفة تماما عن خادم قواعد البيانات» لماذا؟ لأن الخادم يعجز عن توفير هذه 
الخدمة ون الخادم مخصص فقط فقط فقط فقط للجداول والروابط 
والإستعلامات و(نقول فيما بعد). 


ماهي الأدوات التي يمكن إستخدامها لإنشاء النماذج والتقارير... السؤال بسيط 
للغاية والإجابة أبسط منه... الإجابة... أية لغة برمجة يمكنها عمل ذلك: 
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هناك آلاف البرامج والتطبيقات التي تساعدك على عمل هذا بل أفضل من هذا 


Cold Fusion 
FrontPage 
Dream Weaver 


ا 
والممتع جدا في الموضوع أن الآكسس يستخدم (جوجو) لن آقول ما هو جوجو 
!! وهي تساعدك بشكل كبير في إحتراف أي مما سبق. 


ولكن لحظة.... 

كل ما سبق هراء في هراء ومضيعة للوقت والغريب أن الكثيرين والكثيرات 
إرتدوا ملابس السباحة وقفزوا في بركة الفيجوال بيسك لينتهو بنفس العبث 
ونفس الضياع الذي إكتسبوه خطأً من الآأكسس. 


کل اللغات والأدوات السابقة لا قيمة لها بدون آداة صغيرة ولذيذة وخفيفة الدم.. 
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بعد هذه الرحلة من الدروس المتشغية وصلت بك عمدا إلى حائط طويل 


وعريض»» لن تستطيع الإستمرار بدون قفز هذا الحائط.. ان شئت الإستمرار 
فقد حان الوقت لتعلم هذه الأداة» حبذا لو أننا جميعا في قاعة درس لشرحت هذه 
الأداة ووصلت بكم إلى حد الإحتراف في محاضرة واحدة مدتها لا تزيد عن 

أربع ساعات ولكني سأحاول هنا أخذ مفترق للطريق الطويل والشاق والإتجاه 
يمينا لشرح هذه الأداة بسرعة. 


الآن إنسی کل ما درسته في عالم الحاسب ا إرمي قواعد البيانات كلها 
وأترك الطبقة الثالثة وتعال نركز على الطبقة الأولى... 


هيا بنا نقفز أول حائط في طريقنا... الأداة هي HM‏ 
وهي |ختصار Hyper Text Markup Language J‏ 


ورقة بيضاء جديدة وقلم رصاص مبري ومحاية ومسطرة وفنجان قهوة. 

ھيا بنا إJٴ‏ عل HTML‏ 

تحياتي»۰۰ 

مرحباء»» 

لکل من تعلموا وتعلمن H۲۷1‏ بالطرق السیئة متل طریقة e‏ ع٣٤٣٥۴‏ 
سنعود إلى عع ۴۲٥٣۲۴‏ ستروا أن العملية عندما تدرس بشكل منطقي وبفكر 
مختلف تصبح أسهل واوضح و...و... 

أمل من المهتمين توجيه الأخوة والأخوات في منتدي الويب المشاركة معنا. 
لا يوجد صفحة من مليارات الصفحات على الإنترنت أو الإنترانت إلا وهي 


على شكل ۳1۷1 هذا كلام ممتع ويشعر بالغبطة والسرور. 
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ملاحظة أخيرة طرق البرمجة القديمة التي تسمى ٣11٥11 $٥۷٥۲‏ والتي لا 
تعتمد علی ۲۲۷1 بشکل مباشر متثل ہو5 ۴٥۲٥‏ في آوراکل او 
النماذج في آكسس أو وج8 اوuء۷1‏ في MNS SQ‏ هي آخذة في الإنهيار - 
- تقنية (إلى حد ما قديمة) هذا الجيل (نقف له إحتراما) يتوجه الآن وبشكل 
مكثف إلى ۲۲1 » لماذا؟ ببساطة لأن تكلفة الإنتاج بإستخدام HTML‏ 
أرخض بمئات المرات من تلك البرامج وتكلفة الربط والصيانة أرخص. 


ولهذا ستلاحظون سواء الآن أو بعد عشر سنوات أني قفزت على حاجز 
التصميم بإستخدام تقنية S۷‏ "ع11٣‏ والذهاب مباشرة إلى HTML‏ 
وعندما يحاوركم شخص ما عن فؤائد التقنية القديمة» ليس عليكم سوى الإبتسام 
فقط (وعلى مسئوليتي الشخصية) قطعا لن يكون 11۷1 هو الأداة الوحيدة... 
ولكن الممتع هو أن كل اللغات تنتهي في آخر المطاف إلى اM‏ 1[ وها نحن 
نتعلم H1‏ لنرى ما هي نهاية هذا المطاف. 


بإسم الحق نبدا... 


كافة ملفات M1‏ ۲] هي ملفات 1٠×‏ أي نصية 

كافة ملفات ۳1M‏ تنتهي باإمتداد [)ط. مثل [صاط.susu‏ 
كافة ملفات ا1[M[ګ‏ تحتوي على علامات وم u)اه1‏ وكل علامة تعني أمر 
من الاوامر 

كافة العلامات والأوامر توضع بين علامتي <> 

كل أمر من الأوامر (علامة) له بداية وله نهاية 

بداية الأمر على شكل <> 

ونهاية الأمر على شكل </> 

اذا کان لدینا فرضا أمر سمه )عص طA‏ 

فتصبح البداية <Ahmed<>‏ 

</Ahmed> ةيlنلاو‎ 


واضح... 
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أوامر 111 لا يمكن قرائتها وتفسير ها إلى من خلال متصفح ويوجد في 
العالم المئات من المتصفحات ولكن أشهرها إثنان: 


Microsoft Internet Browser 
Netscape Internet Navigator 


الأول من شركة مايكروسوفت وهو شهير في العالم العربي وآسيا 

الثاني من شركة نيتسكيب وهو شهير في أميركا وأوروبا 

لا تنسى ان كتابة الموضوع في عام 2003 

کل ملف ۲۲1[ يجب أن يبدا بالأمر <۲1۷1][[> وينتهي بالأمر 
</HTML>‏ 

ملاحظة العلامة / تكتب قبل الامر و عندما تلاحظها في الامثلة القادمة قم 
بتصحيحها كما في اعلاه 

في جهازك على سطح المكتب إنقر بالزر الأيمن وإختر ... لحظة .. لاتختر 


للذين يستخدمون الويندوز بواجهة عربية أي لديهم (إبدأ) بدلاً من ٤ه‏ أقول 
لهم إتقوا الله في أنفسكم... وإعملو الليلة على إعادة تنصيب الويندوز بواجهة 
إنجليزية (مع عشقي للغة العربية) ... من يريد الإحتراف ويريد مالا فلينفذ ما 
إقترحته فورا. 


بالزر الإيمن على سطح المکتب إختر Text Document ۃ¦ڌî New‏ لإنشاء 
وثيقة نصية على سطح المكتب. لا تغير الإسم» إنقر نقر مزدوج لفتح الوثيقة 
النصية» ثم من القائمة إختر ]۴1 تم ...ئ۸ م2۷؟» الآن ركز... 


في خانة مصهN ۴11e‏ إكتب اصاط. سن ... لا تحفظ الآن ... لحظة 

في الخانة التي تحتھا مرا یھ م۷هS‏ إختر یع۴ ۸11 لتجنب الحفظ بإمتداد 
txt‏ 

أقفل الوثيقة... ماذا تلاحظ على سطح المكتب؟؟؟ 
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أخذت الوثيقة شكل علامة م الخاصة بمستكشف الإنترنت... نقر مزدوج على 
tn1ط.Kuku‏ وسيقوم المستكشف بفتح أول وثيقة إنترنت 11M‏ لك. مرحبا 
بك في HTML pli‏ 


في قائمة المستكشف إضغط علی wWع]۷‏ تم Source JE‏ هذا الأمر يظهر 
لك محتويات الوثيقةء ماذا ترى؟ هههه !! نعم صفحة فارغة!! ماذا كنت تتوقع 
oT‏ 


أغلق صفحة SoUuICe‏ وأترك المستكشف مَفتوحاً علی صفحتنا u)ں‏ ع اذهب 
پقدال , 


الأولی بالضغط علی u)ں‏ × بالزر الأیمن ومن تم إختیار طازسw 0e١‏ ومن 
ثم أختيار برنامج ل2م]هN‏ الذي ياتي مع ویندوز.. 


الثانية هي فتح أي وثيقة نصية ومن تم الأمر ۴1٥‏ تم وعم تم إختيار ۸11 
تم إختیار u)ںk‏ من سطح المکتب. 


الان لدينا )ن مفتوحا كبرمجة في ل2م" ومفتوحا كعرض في مستکشف 
الإنترنت... 


في الوثيقة ٠.111‏ نطبق الشروط أكتب الجملتين التاليتين: 
<HTML>‏ 
</HTML>‏ 


على سطرين منفصلين تحت بعضهما البعض»› الحروف الكبيرة والصغيرة لا 
فرق بینها: 

ثم إضغط زر ۳5 لتحديث الصفحةء الان Ww‏ ع۷1 تم Source‏ ماذا ترى؟ 

کی ا ا ا 
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كل الأوامر في ملف H1‏ يجب أن تكون بين العلامتين <1 11> و 
</HTML>‏ 


انتهينا من القاعدة الأولى والثانية -- مرة أخرى 

القاعدة الأولى يجب أن تبدأً الوثيقة ب <11۷1 > وتنتهي ب </[3#1×M1<‏ 
القاعدة الثانية كافة الأوامر يجب أن تقع بين العلامتين M1‏ ١]؛‏ أي أمر 
خارجهما سيسبب الكثير من المشاكل. 

القاعدة الثانية-- وهي أن الز اس ومر الخسة 

علامة الرأس هي 1٤۸5‏ وعلامة الجسد 805۷ اي جسد الوثيقة أو 
المحتوى الأساسي وتكتب على الشكل التالي: 

<HTML> 


<HEAD> 
</HEAD> 


<BODY> 
</BODY> 


</HTML> 
من ضاع منکم؟‎ 
شرح سريع لما سبق...‎ 


بدأنا الوثيقة ب 1۲1 وأنهيناها بنفس العلامة 
ثم أمر الرأس وأقفلناه» ثم أمر المحتوى وأقفلناه 


ھم أوامر أو علامات الرس ھو أمر العنوان 11٣۴‏ 
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E 
من الآن فصاعداً تتبع الخطوات التالية:‎ 

تعدیل الو ثیفة 1ا ہاط. ku‏ ںK‏ تم تختار Save pۃڌû File‏ 

تم إِذا رغبت في ذلك الضغط کا View‏ تم Source‏ لرؤية المحتويات 


فلل غتران التفكة. 
<HTML>‏ 


<HEAD> 
<TITLE> 
1 love HTML very much 
</TITLE> 
</HEAD> 


<BODY> 
</BODY> 


</HTML> 
لاحظ أن 1)1 يجب أن تكون داخل رأس الوثيقة لهع1]› اي شيء تضعه‎ 
وإقفالها يظهر في أعلى صفحة المستكشف فوق في الأعلى‎ 1)1٥ بين بداية‎ 
في الجزء الأزرق أمل أن تروه... قم بالتجريب والإستمتاع.‎ 
أية معلومات أو محتويات توضع في الجسد او المحتوى او وله8 وأشهر‎ 
٥م العلامات‎ 
وهي إختصار طمهإعهإه۲ أي فقرة..‎ 

<HTML> 


<HEAD> 
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<TITLE> 
1 love HTML very much 
</TITLE> 
</HEAD> 


<BODY> 

<P> 

Hello HTML pals and gals 
</P> 

</BODY> 


</HTML> 
قم بالتجريب...‎ 


الأان ركز معي بشدة... 
لكل علامة من العلامات (الأوامر) تعديلات ... ركز تعديلات... أو فلنسمها 
أوامر فرعية... اي أوامر تساعد على تعديل الأمر وتحسينه.. معظم الأوامر 
لها تعديلات وإضافات. 


كافة الأوامر الفرعية او التعديلات توضع في أمر الإفتتاح وليس الإقفال فمتلا 
مر Body‏ 

يكتب على شكل <5۷ 80> هذ أمر الإفتتاح وهو ما يمكن أن يحتوي على 
التعديلات أما أمر الإغلاق <۷ 805/> فلا يمكن أبدا أن يحتوي على اية 
ن ۰ 


أين توضع التعديلات الفرعيةء مثال: 
<BODY lia>‏ 
تبدأً هكذا 


BODY 
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لاحظ أن ما سبق هو أمر الإفتتاح... 

أشهر التعديلات على أمر رل8 هو لون الخلفية للصفحة... 
<Body bgcolor=blue>‏ 

عدل أمر رل8 حسب ما سبق وجرب... ماذا تلاحظ... 

الأمر الشهير الآخر وهو "ه۴ وله تعديلات كثيره أهما حجم النص لونه 
واسمه ويكتب بالشكل التالي 


>/۴٥⁄×N 1< ويقفل بشكل‎ >FONT1< 


تعالو نعدل الأمر ۲ ونضيف عليه أمر ۴.٤‏ تصبح الوثيقة كما يلي: 


<HTML> 


<HEAD> 
<TITLE> 
1 love HTML very much 
</TITLE> 
</HEAD> 


<BODY bgcolor=blue> 
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<FONT face=arial size=30 color=white> 
<P> 

Hello HTML pals and gals 

</P> 

</FONT> 


</BODY> 


</HTML> 
جرب ما سبق...‎ 


المزعج جدا في ]۳1 انه لا يوجد أخطاءء عندما تركب أمرا بشكل 
خاطىء يتم إهمال الأمر دون إعطائك أية معلومات عن وجود خطأاً !!! وعليه 
لا بد من التدريب المكثف لإكتشاف الأخطاء. 


تعالو نضيف صورة إلى الوثيفة... ضع صورة إسمها عٍمز.ه1ه] في دليل 
c:\Tests‏ 


٠: أضف الجملة التالية‎ 
<HTML> 
<HEAD> 
<TITLE> 
1 love HTML very much 


</ITITLE> 
</HEAD> 


<BODY bgcolor=blue> 
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<FONT face=arial size=30 color=white> 
<P> 

Hello HTML pals and gals 

</P> 

</FONT> 


<IMG src=c:\tests\lolo.jpg></IMG> 
</BODY> 
</HTML> 
وأقفلنا على نفس السطر ولا مشكلة في هذاء‎ [M6 لاحظ أننا فتحنا الأمر‎ 
1M6 أي صو رة» لاحظ أهم تعديلات الأمر‎ [mage إختصار‎ MG الأمر‎ 
آي منبع أو مكان الصورة.‎ $١٥ ويعني‎ 88٣ وهو‎ 


تحت أمر 1۷6 أضف الأمر التالي: 
<IMG wıidth=100 height=100 src=c:\tests\lolo.jpg></IMG>‏ 


جرب» ماذا تلاحظ باستخدام التعديلين hieght gy wıldth‏ قمنا بتعديل حجم 
الصورة!!! 


سأستمر بشرح الأوامر الأساسية للغة M1‏ 11 ولكن لإعطائك تقافة عامة 
وقطعا هذا لا يكفي أبدا... 


نصيحتي... لا تستمر معنا حتى تثق بنفسك وقدراتك على السيطرة على 
HTML‏ 


نستكمل باذن الحق تبارك وتعالى... 


تحیاتی»›»»› 
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الأخ ------ أحي فيكم شجاعتك وتخيلك وإقتحامك فهذه عناصر مبرمج 
مفترس من الدرجة الأولى بغخض النظر عن الإجابة. 


طبعا الإجابة بحد ذاتها (وليس هذا مهما) خاطئة تماماًء لماذا؟ 


أولا لا يوجد شيء إسمه (على الجهاز نفسه) منذ مليار سنة ونحن نقول أن 
en‏ جهاز مختلف تماما عن جهاز 8٥۲۷٥۲‏ ليس لضرورة الإختلاف بل 
لأن البروتوكول المستخدم في ء11٣‏ يختلف عن البروتوكول المستخدم من 
قبل $v‏ اي أن 1M1ګ‏ يختلف عن بروتوکول M18 SQ‏ مثلا. هذا 
موجود على طبقة والآخر على طبقة مختلفة تماما. ولكل طبقة قوانين مختلفة. 


تقول أن عرض النصوص يأخذ تواني !!! هذا غير صحيح على الإطلاق 
ولتصحيح هذا اقول أن النصوص المدرجة في وثيقة M1‏ 11 تعرض بشكل 


من قال أن ياهو يستخدم نفس الخادم !!! غير صحيح لإختلاف البروتوكول 

كلامك صحيح أنه يمكن أن يكون جهازين في نفس المبنى بل في نفس الغرفة 
ولكن ليست المشكلة هنا... المشكلة كيف تم نقل 160 مليون سجل من أمريكا 
إلى السعودية في ثانية أو أقل... ستقول نصوص ... كلام صحيح ولكن حتى 
تورك انكرت ن 60| خرن امحل هاج إلى تف عة إن اك يك 
بضغة ساعات تاهيك عن مشاکل صاع عضن السجلات فی الظریق !! 


الأميال من العميل إلى الخادم والعودة مرة أخرى» وبهذا ليست المشكلة في أن 
Cen‏ لیاهو بجانب ۲ع ۲۷ع لیاهو... 
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اا ن 


من قال آن ياهو يرسل البيانات سجلا سجلا... غير صحيح ولو كان هذا 
صحيحا فستأخذ العملية أياما بل أسابيعا للإنتقال والسفر بين جهازك وبين ياهو 


انت طرحت أسئلة في أجابتك... أشعرتنى بمتعة ضخمة لأتلمس آأين مواطن 
الخلل في شرحي لهذه الدروس وكيفية أن أحاول في أيصال هذه المعلومات 


أشكر شجاعتك وأسلوب تفكيرك الرائع جدا بغض النظر عن النتيجة 
كمبرمجين يهمنا طريقة التفكير والتحليل والإختيار بين البدائل... أما الوصول 
للنتائج فهي للآخرين الأقل مهارة ورتبة منا !!! 


مرة اخرى.... 


لا يوجد شيء أسمه 11ا٤‏ و S٥۷۲‏ على نفس الجهاز ووضعهما على 
نفس الجهاز من الناحية التقية لا بس به ولكن النمن دح 
کال وخ کک ع E‏ 8 
سنتحدث عن موضوع شيق جدا. 


الرحلة بين ٤ا‏ وإم۷إم؟ تتم دائما وأبدا طيلة إتصالك بالإنترنت ولكن 
الحوار بينهما على بروتوكل 111۲ فقط وهذا رائع للنصوص والرسومات 
الضفر 5 (للاكضل انطع و كن عنما تاج خادم 1۲16 إلى قاع 
بيانات فإنه يقوم برحلة إضافية إلى خادم البيانات ومن ثم الحصول عليها 
والعودة ثم إرسالها إٍئى Client‏ 


بدون قواعد بیانات: 


Client 
HTTP Server 
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Client 


بقواعد بیانات: 
Client‏ 

HTTP Server 
Database Server 
HTTP Server 
Client 


ببروتوكول نقل الملفات: 
Client‏ 

FTP Server 

Client 


ببروتوكول البريد الإلكتروني: 
Client‏ 

Email Server 

Client 


سيارة محملة 30 كغم رز تسير بسرعة فائقة 
بينما سيارة محملة نص طن رز --- تحبو .. 


إتصال ينقل 3 سجلات قطعا يختلف عن اتصال ينقل ملايين السجلات سواء 
نصوصأ كانت أم رز لا فرق!!! لأن الحجم هنا تجاوز منطق نوع الوثيقة. نعم 
نقل 3 سجلات نصوص أسرع من نقل 3 سجلات صور» ولكن عندما نتعدى 
منطق العدد وننطلق إلى الملايين تصبح النصوص والصور كلها مصائب... 


كيف نجح 00طه في نقل 160 مليون سجل في أقل من ثانية وفشلنا في نقل 


بضعة سجلات!!! 
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InternetMaster 
ملاحظة: تم حذف اسماء المشاركين منعا للاحراج‎ 


أين نحن؟ نعم في بحر H1 M[‏ وواحدة من أهم العلامات هي إنشاءِ 
الجداول... 


ونستخدم الأمر ۸8۴ ويوضع في منطقة 805۷ إذھب إلى Kuku‏ 
وقبل نهاية علامة وله أدخل العلامة التالية: 


<TABLE> 
</Table> 


قم بالتجريب.... لن يحدث شيء لأن علامة الجدول لا قيمة لها بدون علامة 
السطر... تعالوا نضيف سطرا...وعلامته 1۴ 


<TABLE> 
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<TR> 
</TR> 


</Table> 


جدول فيه سطر واحد فقط... قم بالتجريب» لم يحدث شيئاء لماذا؟ لأن علامة 
السطر لا قيمة لها بدون علامة الخلية... تعالو نضيف خلية ... وعلامتها 11 


<TABLE> 
<TR> 


<TD> 
</TD> 


</TR> 
</TABLE> 
الآن لديك جدول رائع مکون من سطر واحد وعمود واحد. جرب... لا‎ 
شىء!!! لماذا؟ لأن الخلية في الجدول فارغة !! ولكن ماذا لو أردت الخلية أن‎ 
تكون فارغة !! في هذه الحالة لا بد من رسم حدود الجدول وعلامة الحدود‎ 
بهذا الشكل:‎ Tab] هي تعدیل غل علامة‎ 

<TABLE border=2> 

<TR> 


<TD> 
</TD> 


</TR> 
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</TABLE> 

أي أن حدود الجدول سماكتها 2› جرب مممم 
<TABLE border=2>‏ 
<TR>‏ 

<TD></TD> 
<TD></TD> 
<TD></TD> 

</TR> 

</TABLE> 
<TABLE border=2> 
<TR> 
<TD>A</ID> 
<TD>B</ID> 
<TD>C</TD> 
</TR> 

</TABLE> 
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أضف بضعة سطور ... ركز سطور ولیس خلايا... راقب 
<TABLE border=2>‏ 


<TR> 
<TD>A</TD> 
<TD>B</TD> 
<TD>C</TD> 
</TR> 


<TR> 

<TD>3</TD> 
<TD>12</TD> 
<TD>25</TD> 

</TR> 

<TR> 

<TD>9</TD> 
<TD>waaaw</TD> 
<TD>No</TD> 

</TR> 

</TABLE> 

!!! واضح؟؟؟؟ إذا لم يكن إسأل 
...عدل على العمود الأول لتغيير عرض الخلية 
<TABLE border=2>‏ 


<TR> 
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<TD width=250>A</TD> 
<TD>B</TD> 
<TD>C</TD> 

</TR> 


<TR> 
<TD>3</TD> 
<TD>12</TD> 
<TD>25</TD> 
</TR> 


<TR> 
<TD>9</TD> 
<TD>waaaw</ITD> 
<TD>No</TD> 
</TR> 


</TABLE> 

....ألان قم بالتجارب التالية على الخلايا 

<TD bgcolor=yell0ow>B</1 D> لتغيير خلفية الخلية‎ 

<TD align=center bgcolor=yell0ow>B</TD5> لتو سيط النص في‎ 
<TD><IMG width=200 height=200 


ما هذا؟؟؟ نعم صورة في src=c:\tests\lolo.jpg></1MG></1]D>‏ 
!! الخلية 
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من يرسم لي جدولاً فيه رقم المريض» جنس امون عمر المريض ويدخل 
5 صفوقف بحیث یکون کل صف بلون مختلف والبيانات في منتصف كل 
خأبة؟ 


تحياتي»۰۰ 
مرحباء»» 


أسعدني بشدة تفاعلكم مع الموضوع» وهذا يشجعني دائما على الإستمرار.. 
کت غر اک ومسا ماک ےار دال کے ا مکو کے 


ن 
الإجابات لم تكن فكرا صافيا وعميقا لل 1۲1 بل أن بعض الرسائل 
الواردة هي نسخ ولصق من برامج أخرى متل عع ه۲۴٥۴‏ وهذا فيه إساءة 
لأبسط أنواع التفكير !!! 


لكت بلحل هذا!!! CS EE‏ 
| أل تشارك بالإجابة أف الأفضل ا تشارك في إطار ما درسناه فقط 111 
على أية حال مازالت نصيحتي أن نتعلم 111 من خلال برنامج المفكرة 
4مءN0t‏ وليس من خلال أية برامج أخرى... سنعود لهذه البرامج مثل 
Page‏ ntدا۴‏ لكن عندما نعود لها ستكون مجرد لقمة سائغة وسهلة البلع 
والإستيعاب. 


يسوؤني أن هذا المنتدى لديه مشكلة في التعامل مع اللغتين العربية والإنجليزية 
فی نفس الوقت وقد رأيت بعض مشاركاتى ومشاركات الأخوة والأخوات أن 
الجمل البرمجية تنقلب رأسا على عقب وليتهم يجدون حلا لهذا. على أية حال 
آمل أن الجميع قد لاحظ أن علامة الإقفال لكل أوامر ۲11 تبدأ بالإشارة / 
ولا تنتهي بها !!! 
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يسوؤني أنني كلما هممت بإضافة مشاركة جديدة لهذا المنتدى الطيب تنهال 
علي الأعمال والإرتباطات والمواعيد من كل حدب وصوب وأخشى أن هذا 
الإنشغال يصرف المشاركين والمهتمين ويعلم الله أني مليء بالحماس والرغبة 
أكثر منكم وأصبحت مشاركاتي العشوائية الغير منظمة مشكلة لي بالمقام الأول 
قبل أن تكون سيئة بالنسبة لكم. 


وها آنا ذا أحاول بكل جد أن أجد مخرجا لتنظيم هذه المشاركات حيث أن 
مشاركة أو إثنتين في أوقات محددة أفضل من عشرين مشاركة عشوائية !! كل 
ما أرجوه أن أن تدعو لي وأن تصبروا... والله مع الصابرين. 


لن نستمر كثيرا في عالم 111 لأن الطريق 


جدا !! 


كل ما أرجوه هو أن أكون قائدا ناجحا لكم لإختراق الغابة!!! نعم كل ما أعمله 
هنا هو أن آخذ بأيديكم بتوفيق الله من ضفة إلى أخرى مع إعطائكم لمحات 
لأسس وقوانين كل محطة وأستراحة في هذه الغابة... عند وصولکم إلى الضفة 
الأخرى سيكون الأمر واضحا وجليا لكم وكل ما يتطلبه الأمر منك هو العودة 
مرة أخرى لكل محطة وإستراحة وإتقانها بشكل جيد... في تلك اللحظة سيكون 
لديك خريطة كاملة وواضحة تشرح من أين نبد وإلى أين ننتهي وكيف ندر 
اګ لغة (إن جاز أن نرقيها إلى لغة) سهلة للغاية ولا تتطلب سوى أن 
تفتحوا الدفاتر وتضعو سردا سريعا لكافة أوامرها... ثم تتعاملون مع كل أمر 
على حدةء ثم بعد ذلك تتعاملون مع العلامات الفرعية لكل أمر» ثم في النهاية 
ممارسة هذه الأوامر لعدة أسابيع وأقترح ألا تقل عن أسبوعين مكثفين. 


أسبوعين بإستخدام الورقة والقلم (ولست بحاجة إلى إعادة تأكيد هذا ... لاحظ 
ورقة وقلم) و ك2 مء†هN‏ كافية جدا لتحويلك إلى شخص مفترس لل HTML‏ 


تعالوا نسرد أوامر M1‏ 11: ولا تنسوا أن تسجلوها في دفاتركم !!!! 
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أو امر تعاملنا معها: 
<HTML>‏ 
<HEAD>‏ 
<TITLE>‏ 
<BODY>‏ 
<P>‏ 
<FONT‏ 
<TABLE>‏ 
<TR>‏ 
<TD>‏ 
<IMG>‏ 


أوامر هام ةة جدا لم نتعامل معها: 
<۸> للرىط بین وتیقتین H۳ 1M‏ مختلفتین 


<8> لجعل الخط عريض غامق 8014 وتستخدم بهذا الشكل: 
<P><B>Hellloooooo0o00</B></P>‏ 


<[> لجعل الخط مائل ٥1إه]]‏ وتستخدم بهذا الشكل: 
<P><ÞHellloooooooo00</I®</P>‏ 


<U>‏ لرسم خط تحت النص عہUnderl1‏ وتستخدم حسب ما سبق 


R<‏ 8> للانتقال إلى سطر جديد بدون فقرة جديدة -- لاحظ أن هذه العلامة 
ليس لها علامة إقفال !!! أي لا يوجد شيء أسمه < 8/> !! 


<3> لرسم سطر وليس لها علامة إقفال !! ركز !! 
>٤ N۲٤R<‏ لتوسيط أي شيء سواء نص أو فقرة أو صورة أو جدول 


إلخ.. 


188 


<> إختصار ل ٣٥ع)!‏ )ی11 للترقیم على شکل نقاط 
<> للترقیم على شکل نقاط 
<0> للترقیم علی شکل نقاط 


أوامر لم نتعامل معها ذات أهمية أقل لأنها تمثل فكرا للزخرفة والفن وليس 

للبرمجة: 

<MAP>‏ ونستخدم معها <AREA>‏ وذلك لتقسيم أي صور ةه ة إلى صفحات 
تلفة للانتقال 

>۴RAM ٤<‏ لوضع أكثر من صفحة في صفحة 111 واحدة (تقنية 

قديمة جدا) 

>EM B٤ D<‏ لإلحاق برامج آخرى بصفحة ]11 مثل فلاش وغیرہ 


أوامر البرمجة -- مرحبا بكم: 
<DIV>‏ إختصار Division JÛ‏ 
<scrip>‏ 

<INPUT 

<FORM> 


أما الأوامر الأخرى فدعك منها (على مسئوليتي الشخصية) !!! فيما عدا الأمر 
>N E81 ۸<‏ وهذا قصة قائمة بذاتها !!! ! ذكروني فيه ذات يوم بعد التخرج 111 


EEE E Ea E a 
لمراجعة كل ما سبق وهناك آلأف المواقع التي ت تشرح كل ما سبق بالتفصيل‎ 
الممل جدا ولا بأس في كتاب واحد (((((((((فقط)))))))))) لا داعي لأكثر من‎ 


هذا. 
كل ما أطلبه عدم الإنتقال إلى خطوتنا التالية إلا ولديك ثقة عالية بنفسك في 


HTML JI lle‏ > بعد ممارسة ]1[ والتدرب عليها إفتح أي موقع على 
الإنترنت ومن تم من قائمة WwW‏ ع۷1 إختر ع٥‏ uه؟‏ ماذا تری؟؟؟؟ 
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سترى عالما مريحا وممتعا جدا ... سترى أن الصفحة التي قمت بفتحها ليست 
غريبة عليك على الإطلاق... 


صدق أو لا تصدق أن ما سبق يشكل إحتياجك ل %95 من عاpl HTML‏ !!! 


بعد هذا سنركز على الأوامر الثلاثة الخاصة بالبرمجة ونأخذ بضعة أمثلة 
وتمارین ثم ننطلق إلى عالم DH] M1‏ ومنھ نذھب إلی عالم ۸8۶ ثم نعود 
مرة أخرى إلى قواعد البيانات ونرى كيف نخلط الأربعة في كأس عصير 
منعش !!! 


تحیاتی›۰» 
مرحباء»» 


ملاحظة سريعة وهي أن 1۲[ آخذة في الزوال مثل ۲۲1 و ۸8۲ أي أنها 
تقنيات عام 2001 وما قبله» )N6[.م۸p‏ وال ۾ ره[ ما زلا فرسي الرهان حتى 


الآن والسباق بينهما!! 
تحياتي»۰۰ 
مرحباء»» 


اللأخ ----»»» معظم علامات H1M1‏ لا تتطلب علامة الإقفال أي أن علامة 
الأمر أيضا على علامة الخلية !!! 


ولكن لحظة !!! 
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نصيحتي أن تمارس إقفال كافة العلامات فيما عدا تلك التي ليس لها علامات 


. ۰ 
۹ 


إقفال مٿل >BR><‏ ڍر .<>HR>‏ 


إن التعود على إقفال كافة العلامات سيساعدك بشدة وبقوة عند البدء في برمجة 
HTML‏ و .ASP ys DHTML‏ 


تحياتي»۰۰ 
مرحباء»» 


رائع جدا... وشكرا للتوجيه»ء وأن كان القصد كتابة الجملة الإنجليزية خلال 
وضمن النص العربي. متثل كتابة 5٤<‏ 0)/> أو .>/)05٤<‏ عموما لك 
جزيل الشكر. توجيهك لي سيخفف عبء کكبير. 

أما بخصوص المسابقة... فآمل إعطائي مهلة حتى 1 يناير قبل إعلان فشلي في 
تحديد الأسئلة لضيق الوقت» بعد هذه المدة وعند إعلان فشلي سأنقل هذه 
المهمة لكم لتحديد شكل ونوع المسابقة حسب ما ترونه وتقييم المشاركات 
وفرزها وإعلان فائز وفائزة. 

وسيكون دوري محصورا في منح الجائزتين فقط. 

سأحاول جادا ومتكلا على الله في إنهاء المهمة قبل بداية العام الجديد. 


تحیاتی»›»»› 


وفي النهاية أقول : أستاذي llعjıj internet master‏ 
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جزآكم الله كل خير ولك جزیل الشكر 
فقد كانت رحلة ممتعة ومفيدة 

أمد الله في عمرك و أفاد بك امتنا العربية 
وعسى أن يوفقنا الله لرد الجميل 


فغ ي 

عماد حمدي یوسف 
العراق بغداد 

السبت» نيسان 03ء 2010 


2010/12/04 


عماد حمدي العكيلي 


EMAD HAMDY Y 
مصمم الکتاب‎ 
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